標籤:ret 自動 http ble nts 情況 lsp 程式 return
C++提供了關鍵字explicit,可以阻止不應該允許的經過轉換建構函式進行的隱式轉換的發生。聲明為explicit的建構函式不能在隱式轉換中使用。
C++中, 一個參數的建構函式(或者除了第一個參數外其餘參數都有預設值的多參建構函式), 承擔了兩個角色。 1 是個構造器 ,2 是個預設且隱含的類型轉換操作符。所以, 有時候在我們寫下如 AAA = XXX, 這樣的代碼, 且恰好XXX的類型正好是AAA單參數構造器的參數類型, 這時候編譯器就自動調用這個構造器, 建立一個AAA的對象。這樣看起來好象很酷, 很方便。 但在某些情況下(見下面權威的例子), 卻違背了我們(程式員)的本意。 這時候就要在這個構造器前面加上explicit修飾, 指定這個構造器只能被明確的調用/使用, 不能作為類型轉換操作符被隱含的使用。explicit建構函式的作用解析:explicit建構函式是用來防止隱式轉換的。請看下面的代碼:
| 123456789101112131415161718192021222324252627 |
class Test1{public: Test1(int n) { num=n; }//普通建構函式private: int num;};class Test2{public: explicit Test2(int n) { num=n; }//explicit(顯式)建構函式private: int num;};int main(){ Test1 t1=12;//隱式調用其建構函式,成功 Test2 t2=12;//編譯錯誤,不能隱式調用其建構函式 Test2 t2(12);//顯式調用成功 return 0;} |
Test1的建構函式帶一個int型的參數,代碼23行會隱式轉換成調用Test1的這個建構函式。而Test2的建構函式被聲明為explicit(顯式),這表示不能通過隱式轉換來調用這個建構函式,因此代碼24行會出現編譯錯誤。普通建構函式能夠被隱式調用。而explicit建構函式只能被顯式調用。
c++ explicit