C++ explicit關(guān)鍵字講解
前言:
C++編碼時(shí),可以通過構(gòu)造函數(shù)將相應(yīng)的數(shù)據(jù)類型轉(zhuǎn)換成為C++類的對(duì)象,從某種程度來說給編碼帶來了方便,但并不是每次都正確,為了避免這種情況,C++提供了explicit關(guān)鍵字,相對(duì)于implicit而言,他默認(rèn)關(guān)閉了隱式類型轉(zhuǎn)換方法。至于兩者有什么區(qū)別,通過下面的代碼進(jìn)行比較說明。
1 隱式轉(zhuǎn)換
C++ 構(gòu)造函數(shù)默認(rèn)類型為implicit,定義時(shí)既可以顯示說明也可以默認(rèn)不加該標(biāo)識(shí)符。
// 沒有使用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í)例化的過程中主要進(jìn)行了如下操作:
CString string5(6); //或者如下所示 CString temp(6); CString string5 = temp;
2 顯示轉(zhuǎn)換
在構(gòu)造函數(shù)上使用了explicit關(guān)鍵字后,通過構(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)容如下:

通過運(yùn)行結(jié)果可以說明: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)容為:

如果要解決上面的問題可以用下面得到方法:
按照顯示類型轉(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/C++實(shí)現(xiàn)高并發(fā)http服務(wù)器的代碼示例
這篇文章簡(jiǎn)單給大家介紹了C/C++實(shí)現(xiàn)高并發(fā)http服務(wù)器的代碼示例,文章通過代碼和圖文介紹的非常詳細(xì),感興趣的同學(xué)可以參考閱讀2023-07-07
C++繼承中的對(duì)象構(gòu)造與析構(gòu)和賦值重載詳解
這篇文章主要為大家詳細(xì)介紹了C++繼承中的對(duì)象構(gòu)造與析構(gòu)和賦值重載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
VS2019中CMake項(xiàng)目如何指定c++語(yǔ)言標(biāo)準(zhǔn)
這篇文章主要介紹了VS2019中CMake項(xiàng)目如何指定c++語(yǔ)言標(biāo)準(zhǔn),需要的朋友可以參考下2020-02-02
C++實(shí)現(xiàn)將簡(jiǎn)單密碼譯回原文的方法
這篇文章主要介紹了C++實(shí)現(xiàn)將簡(jiǎn)單密碼譯回原文的方法,可實(shí)現(xiàn)將簡(jiǎn)單的字母位移類型的密碼譯回原文的功能,涉及C++簡(jiǎn)單字符串操作相關(guān)技巧,需要的朋友可以參考下2016-05-05
C++實(shí)現(xiàn)一個(gè)簡(jiǎn)單的線程池的示例代碼
本文主要介紹了C++實(shí)現(xiàn)一個(gè)簡(jiǎn)單的線程池的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
關(guān)于C++中定義比較函數(shù)的三種方法小結(jié)
下面小編就為大家?guī)硪黄P(guān)于C++中定義比較函數(shù)的三種方法小結(jié)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之圖的遍歷實(shí)例詳解
這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之圖的遍歷實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07
C++中typedef 及其與struct的結(jié)合使用
這篇文章主要介紹了C++中typedef 及其與struct的結(jié)合使用,需要的朋友可以參考下2014-02-02

