c++ explicit建構函式
explicit按字面意思是明確的,顯式的。在c++類中只要定義的建構函式編譯器就不會幫你生成預設建構函式。
按照預設規定,只有乙個引數的建構函式也定義了乙個隱式轉換,將該建構函式對應資料型別的資料轉換為該類物件,如下面所示:
class string
string str = 「hello world!」; //ok 隱式轉換,等價於string str = string(「hello world!」);
但是有的時候可能會不需要這種隱式轉換,如下:
class string
下面兩種寫法比較正常:
string str1 ( 20 ); //ok 分配20個位元組的空字串
string str2 = string ( 20 ); //ok 分配20個位元組的空字串
下面兩種寫法就比較疑惑了:
string str4 = 20; //編譯通過,也是分配20個位元組的空字串
string str5 = 『a』; //編譯通過,分配int(『a』)個位元組的空字串
str4 和str5 分別把乙個int型和char型,隱式轉換成了分配若干位元組的空字串,容易令人誤解。
為了避免這種錯誤的發生,我們可以宣告顯示的轉換,使用explicit 關鍵字:
class string
加上explicit,就抑制了string ( int n )的隱式轉換,
下面兩種寫法仍然正確:
string s2 ( 20 ); //ok 分配20個位元組的空字串
string s3 = string ( 20 ); //ok 分配20個位元組的空字串
下面兩種寫法就不允許了:
string s4 = 20; //編譯不通過,不允許隱式的轉換
string s5 = 『a』; //編譯不通過,不允許隱式的轉換
這 就是explicit的作用,需要顯式轉換,不過該關鍵字只能用於建構函式。
C 中explicit建構函式的理解
普通的建構函式可以被顯式呼叫和隱試呼叫,但是explicit的建構函式只能被顯式的呼叫,不能被隱試的呼叫。示例如下 class test0 class test1 int main int argc,char ar 分析如下 include include using namespace std c...
explicit建構函式
按照預設規定,只有乙個引數的建構函式也定義了乙個隱式轉換,將該建構函式對應資料型別的資料轉換為該類物件,如下面所示 class string string s1 hello ok 隱式轉換,等價於string s1 string hello 但是有的時候可能會不需要這種隱式轉換,如下 class s...
explicit建構函式
在閱讀slicer原始碼時,遇見explicit修飾的建構函式,比較迷惑 explicit qslicerigsreadermodule qobject parent 0 下面就解釋這個問題。按照預設規定,只有乙個引數的建構函式也定義了乙個隱式轉換,將該建構函式對應資料型別的資料轉換為該類物件,如下...