C++ explicit關(guān)鍵字講解
前言:
C++編碼時(shí),可以通過(guò)構(gòu)造函數(shù)將相應(yīng)的數(shù)據(jù)類型轉(zhuǎn)換成為C++類的對(duì)象,從某種程度來(lái)說(shuō)給編碼帶來(lái)了方便,但并不是每次都正確,為了避免這種情況,C++提供了explicit關(guān)鍵字,相對(duì)于implicit而言,他默認(rèn)關(guān)閉了隱式類型轉(zhuǎn)換方法。至于兩者有什么區(qū)別,通過(guò)下面的代碼進(jìn)行比較說(shuō)明。
1 隱式轉(zhuǎn)換
C++ 構(gòu)造函數(shù)默認(rèn)類型為implicit,定義時(shí)既可以顯示說(shuō)明也可以默認(rèn)不加該標(biāo)識(shí)符。
// 沒(méi)有使用explicit關(guān)鍵字的類聲明, 即默認(rèn)為隱式聲明
class CString{
private:
char *m_pStr;
int m_iSize;
public:
CxString(int size){
m_iSize = size;
m_pStr = malloc(m_iSize + 1);
memset(m_pStr, 0, m_iSize + 1);
}
CxString(const char *p) {
int size = strlen(p);
m_pStr = malloc(size + 1);
strcpy(m_pStr, p);
m_iSize = strlen(m_pStr);
}
~ CxString(){
if(m_pStr)
{
delete m_pStr;
m_pStr = nullptr;
}
}
};
如上的代碼中在實(shí)例化類的對(duì)象時(shí)以下方法都是正確的。
如下所示:
CString str1("12121");//CxString(const char *p)
CString str2="abc";//CxString(const char *p)
CString str4(4);//CxString(int size)
CString str5=6;//CxString(int size)
上面的使用方式都會(huì)默認(rèn)調(diào)用相應(yīng)的構(gòu)造函數(shù)實(shí)現(xiàn)對(duì)象的初始化,以CString str5=6為例,在對(duì)對(duì)象進(jìn)行實(shí)例化的過(guò)程中主要進(jìn)行了如下操作:
CString string5(6); //或者如下所示 CString temp(6); CString string5 = temp;
2 顯示轉(zhuǎn)換
在構(gòu)造函數(shù)上使用了explicit關(guān)鍵字后,通過(guò)構(gòu)造函數(shù)進(jìn)行對(duì)象實(shí)例化時(shí)需要進(jìn)行顯示類型轉(zhuǎn)化。否則將會(huì)報(bào)錯(cuò)。
依舊以上面的代碼為例:
class CString{
private:
char *m_pStr;
int m_iSize;
public:
explicit CString(int size) {
m_iSize = size;
m_pStr = (char *)malloc(m_iSize + 1);
memset(m_pStr, 0, m_iSize + 1);
}
explicit CString(const char *p){
int size = strlen(p);
m_pStr = (char *)malloc(size + 1);
strcpy(m_pStr, p);
m_iSize = strlen(m_pStr);
}
};
如上:再次使用相同得到方式對(duì)類進(jìn)行實(shí)例化時(shí)將會(huì)報(bào)錯(cuò),報(bào)錯(cuò)內(nèi)容如下:

通過(guò)運(yùn)行結(jié)果可以說(shuō)明:explicit關(guān)鍵字可以防止構(gòu)造函數(shù)進(jìn)行隱式自動(dòng)轉(zhuǎn)換
3 再次拆解
explicit關(guān)鍵字只對(duì)構(gòu)造函數(shù)有一個(gè)參數(shù)的形式有效,如果構(gòu)造函數(shù)有多個(gè)參數(shù)時(shí)explicit的功能也將失效,但是C++也提供了一種例外,既如果構(gòu)造函數(shù)的其他參數(shù)都有默認(rèn)值及時(shí)參數(shù)個(gè)數(shù)大于1個(gè)explicit也是生效的。
如下面的代碼所示:
class CPoint
{
private:
float m_fX;
float m_fY;
public:
explicit CPoint(float x,float y=9.8):m_fX(x),m_fY(y)
{
}
};
int main()
{
CPoint point1(2,3);
CPoint point2=4.5;
return 0;
}
如代碼所示,編譯時(shí)將會(huì)報(bào)錯(cuò),報(bào)錯(cuò)內(nèi)容為:

如果要解決上面的問(wèn)題可以用下面得到方法:
按照顯示類型轉(zhuǎn)換的方式進(jìn)行處理,如:
CPoint point1(2,3); CPoint point2(4.5);
將explicit關(guān)鍵字去掉,允許構(gòu)造函數(shù)進(jìn)行隱式轉(zhuǎn)換數(shù)據(jù)類型,如:
CPoint(float x,float y=9.8):m_fX(x),m_fY(y)
{
}
到此這篇關(guān)于C++ explicit關(guān)鍵字講解的文章就介紹到這了,更多相關(guān)C++ explicit關(guān)鍵字內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ 將文件數(shù)據(jù)一次性加載進(jìn)內(nèi)存實(shí)例代碼
這篇文章主要介紹了C++ 將文件數(shù)據(jù)一次性加載進(jìn)內(nèi)存實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05
C/C++題解LeetCode1295統(tǒng)計(jì)位數(shù)為偶數(shù)的數(shù)字
這篇文章主要為大家介紹了C/C++題解LeetCode1295統(tǒng)計(jì)位數(shù)為偶數(shù)的數(shù)字示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
C語(yǔ)言使用深度優(yōu)先搜索算法解決迷宮問(wèn)題(堆棧)
這篇文章主要介紹了C語(yǔ)言使用深度優(yōu)先搜索算法解決迷宮問(wèn)題,涉及C語(yǔ)言堆棧的使用與深度優(yōu)先算法解決迷宮問(wèn)題的相關(guān)操作技巧,需要的朋友可以參考下2017-09-09

