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