具體:
帶單一引數的建構函式在預設情況下隱含乙個轉換操作符,請看下面的**:
class myclass
void fun()
編譯器重新編輯上述例子**,如下:
///"c=5;" 被編譯器轉換成下面這個樣子:
/myclass temp(5);// 例項化乙個臨時物件,
c = temp; // 用 = 賦值
temp.myclass::~myclass(); // temp 的析構函式被啟用
在很多情況下,這個轉換是有意的,並且是正當的。但有時我們不希望進行這種自動的轉換,例如:
class string ;
void f ()
為了避免這樣的隱式轉換,應該象下面這樣顯式宣告該帶單一引數的建構函式:
class string ;
void f ()
認識 C 中的explicit 關鍵字
帶單一引數的建構函式在預設情況下隱含乙個轉換操作符,請看下面的 class myclass void fun 編譯器重新編輯上述例子 如下 c 5 被編譯器轉換成下面這個樣子 myclass temp 5 例項化乙個臨時物件,c temp 用 賦值 temp.myclass myclass temp...
c 中explicit關鍵字
c 中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的。既然有 顯式 那麼必然就有 隱式 那麼什麼是顯示而什麼又是隱式的呢?按照預設規定,只有乙個引數的建構函式也定義了乙個隱式轉換,將該建構函式對應資料型別的資料轉換為該類物件,如下面所示 include using namesp...
c 中的explicit關鍵字
c 中的explicit關鍵字 c 中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的,既然有 顯式 那麼必然就有 隱式 那麼什麼是顯示而什麼又是隱式的呢?如果c 類的建構函式有乙個引數,那麼在編譯的時候就會有乙個預設的轉換操作 將該建構函式對應資料型別的資料轉換為該類物件,如下...