c++中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的,
既然有"顯式"那麼必然就有"隱式",那麼什麼是顯示而什麼又是隱式的呢?
如果c++類的建構函式有乙個引數,那麼在編譯的時候就會有乙個預設的轉換操作:
將該建構函式對應資料型別的資料轉換為該類物件
,如下面所示:
class myclass
....
myclass obj = 10; //ok,convert int to myclass
在上面的**中編譯器自動將整型轉換為myclass類物件,實際上等同於下面的操作:
myclass temp(10);
myclass obj = temp;
上面的所有的操作即是所謂的"隱式轉換"。
如果要避免這種自動轉換的功能,我們該怎麼做呢?嘿嘿這就是關鍵字explicit的作用了,將類的建構函式宣告為"顯示",也就是在宣告建構函式的時候前面新增上explicit即可,這樣就可以防止這種自動的轉換操作,如果我們修改上面的myclass類的建構函式為顯示的,那麼下面的**就不能夠編譯通過了,如下所示:
class myclass
........
myclass obj = 10; //err,can't non-explict convert
**
C 的explicit關鍵字
c 的explicit關鍵字 c 中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的,既然有 顯式 那麼必然就有 隱式 那麼什麼是顯示而什麼又是隱式的呢?如果c 類的建構函式有乙個引數,那麼在編譯的時候就會有乙個預設的轉換操作 將該建構函式對應資料型別的資料轉換為該類物件,如下面...
C 的explicit關鍵字
c 中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的,既然有 顯式 那麼必然就有 隱式 那麼什麼是顯示而什麼又是隱式的呢?如果c 類的建構函式有乙個引數,那麼在編譯的時候就會有乙個預設的轉換操作 將該建構函式對應資料型別的資料轉換為該類物件,如下面所示 class myclas...
C 的explicit關鍵字
帶單一引數的建構函式在預設情況下隱含乙個轉換操作符,請看下面的 class c void f 編譯器重新編輯上述例子 如下 c 5 被編譯器轉換成下面這個樣子 c temp 5 例項化乙個臨時物件,c temp 用 賦值 temp.c c temp 的析構函式被啟用 在很多情況下,這個轉換是有意的,...