C 中的explicit建構函式

2021-06-26 00:31:38 字數 985 閱讀 1617

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 下面就解釋這個問題。按照預設規定,只有乙個引數的建構函式也定義了乙個隱式轉換,將該建構函式對應資料型別的資料轉換為該類物件,如下...