在c++中,我們有時可以將建構函式用作自動型別轉換函式。但這種自動特性並非總是合乎要求的,有時會導致意外的型別轉換,因此,c++新增了關鍵字explicit,用於關閉這種自動特性。即被explicit關鍵字修飾的類建構函式,不能進行自動地隱式型別轉換,只能顯式地進行型別轉換。
注意:只有乙個引數的建構函式,或者建構函式有n個引數,但有n-1個引數提供了預設值,這樣的情況才能進行型別轉換。
下面通過一段**演示具體應用(無explicit情形):
/* 示例**1 */
2class
demo
3;
上述四種建構函式:
建構函式1沒有引數,無法進行型別轉換!
建構函式2有乙個引數,可以進行型別轉換,如:demo test; test = 12.2;這樣的呼叫就相當於把12.2隱式轉換為demo型別。
建構函式3有兩個引數,且無預設值,故無法使用型別轉換!
建構函式4有3個引數,其中兩個引數有預設值,故可以進行隱式轉換,如:demo test;test = 10; 。
下面講述使用了關鍵字explicit的情況:
複製**
/* 示例**2 */22
class
demo33
;
在上述建構函式2中,由於使用了explicit關鍵字,則無法進行隱式轉換。即:demo test;test = 12.2;是無效的!但是我們可以進行顯示型別轉換,如:
demo test;
test = demo(12.2); 或者
test = (demo)12.2;
c 中explicit關鍵字
c 中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的。既然有 顯式 那麼必然就有 隱式 那麼什麼是顯示而什麼又是隱式的呢?按照預設規定,只有乙個引數的建構函式也定義了乙個隱式轉換,將該建構函式對應資料型別的資料轉換為該類物件,如下面所示 include using namesp...
c 中的explicit關鍵字
c 中的explicit關鍵字 c 中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的,既然有 顯式 那麼必然就有 隱式 那麼什麼是顯示而什麼又是隱式的呢?如果c 類的建構函式有乙個引數,那麼在編譯的時候就會有乙個預設的轉換操作 將該建構函式對應資料型別的資料轉換為該類物件,如下...
c 中的explicit關鍵字
c 中的explicit關鍵字用來修飾類的建構函式,表明該建構函式是顯式的,既然有 顯式 那麼必然就有 隱式 那麼什麼是顯示而什麼又是隱式的呢?如果c 類的建構函式有乙個引數,那麼在編譯的時候就會有乙個預設的轉換操作 將該建構函式對應資料型別的資料轉換為該類物件,如下面所示 class myclas...