C++中的explicit關(guān)鍵字實例淺析
在C++程序中很少有人去使用explicit關(guān)鍵字,不可否認(rèn),在平時的實踐中確實很少能用的上。再說C++的功能強大,往往一個問題可以利用好幾種C++特性去解決。但稍微留心一下就會發(fā)現(xiàn)現(xiàn)有的MFC庫或者C++標(biāo)準(zhǔn)庫中的相關(guān)類聲明中explicit出現(xiàn)的頻率是很高的。了解explicit關(guān)鍵字的功能及其使用對于我們閱讀使用庫是很有幫助的,而且在編寫自己的代碼時也可以嘗試使用。既然C++語言提供這種特性,我想在有些時候這種特性將會非常有用。
按默認(rèn)規(guī)定,只用傳一個參數(shù)的構(gòu)造函數(shù)也定義了一個隱式轉(zhuǎn)換。舉個例子:
(下面這個CExample沒有什么實際的意義,主要是用來說明問題)
//Example.h
#pragma once
class CExample
{
public:
CExample(void);
public:
~CExample(void);
public:
int m_iFirst;
int m_iSecond;
public:
CExample(int iFirst, int iSecond = 4);
};
//Example.cpp
#include "StdAfx.h"
#include "Example.h"
CExample::CExample(void)
: m_iFirst(0)
{
}
CExample::~CExample(void)
{
}
CExample::CExample(int iFirst, int iSecond):m_iFirst(iFirst), m_iSecond(iSecond)
{
}
//TestExplicitKey.cpp
...//其它頭文件
#include "Example.h"
int _tmain(int argc, _TCHAR* argv[])
{
CExample objOne; //調(diào)用沒有參數(shù)的構(gòu)造函數(shù)
CExample objTwo(12, 12); //調(diào)用有兩個參數(shù)的構(gòu)造函數(shù)
CExample objThree(12); //同上,可以傳一個參數(shù)是因為該構(gòu)造函數(shù)的第二個參數(shù)有默認(rèn)值
CExample objFour = 12; //執(zhí)行了隱式轉(zhuǎn)換,等價于CExample temp(12);objFour(temp);注意這個地方調(diào)用了
//編譯器為我們提供的默認(rèn)復(fù)制構(gòu)造函數(shù)
return 0;
}
如果在構(gòu)造函數(shù)聲明中加入關(guān)鍵字explicit,如下
explicit CExample(int iFirst, int iSecond = 4);
那么CExample objFour = 12; 這條語句將不能通過編譯。在vs05下的編譯錯誤提示如下
error C2440: 'initializing' : cannot convert from 'int' to 'CExample'
Constructor for class 'CExample' is declared 'explicit'
對于某些類型,這一情況非常理想。但在大部分情況中,隱式轉(zhuǎn)換卻容易導(dǎo)致錯誤(不是語法錯誤,編譯器不會報錯)。隱式轉(zhuǎn)換總是在我們沒有察覺的情況下悄悄發(fā)生,除非有心所為,隱式轉(zhuǎn)換常常是我們所不希望發(fā)生的。通過將構(gòu)造函數(shù)聲明為explicit(顯式)的方式可以抑制隱式轉(zhuǎn)換。也就是說,explicit構(gòu)造函數(shù)必須顯式調(diào)用。
引用一下Bjarne Stroustrup的例子:
class String{
explicit String(int n);
String(const char *p);
};
String s1 = 'a'; //錯誤:不能做隱式char->String轉(zhuǎn)換
String s2(10); //可以:調(diào)用explicit String(int n);
String s3 = String(10);//可以:調(diào)用explicit String(int n);再調(diào)用默認(rèn)的復(fù)制構(gòu)造函數(shù)
String s4 = "Brian"; //可以:隱式轉(zhuǎn)換調(diào)用String(const char *p);再調(diào)用默認(rèn)的復(fù)制構(gòu)造函數(shù)
String s5("Fawlty"); //可以:正常調(diào)用String(const char *p);
void f(String);
String g()
{
f(10); //錯誤:不能做隱式int->String轉(zhuǎn)換
f("Arthur"); //可以:隱式轉(zhuǎn)換,等價于f(String("Arthur"));
return 10; //同上
}
在實際代碼中的東西可不像這種故意造出的例子。
發(fā)生隱式轉(zhuǎn)換,除非有心利用,隱式轉(zhuǎn)換常常帶來程序邏輯的錯誤,而且這種錯誤一旦發(fā)生是很難察覺的。
原則上應(yīng)該在所有的構(gòu)造函數(shù)前加explicit關(guān)鍵字,當(dāng)你有心利用隱式轉(zhuǎn)換的時候再去解除explicit,這樣可以大大減少錯誤的發(fā)生。
以上所述是小編給大家介紹的C++中的explicit關(guān)鍵字實例淺析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Visual Studio 2022 上使用ffmpeg的詳細(xì)步驟
文章介紹了在開發(fā)項目中配置FFmpeg庫的步驟,添加包含目錄、庫目錄、依賴項及動態(tài)庫路徑,確保編譯器和鏈接器正確識別FFmpeg資源,最后通過測試驗證配置有效性,感興趣的朋友一起看看吧2025-07-07
C語言實現(xiàn)通訊管理系統(tǒng)設(shè)計
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)通訊管理系統(tǒng)設(shè)計,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01

