C++中的explicit

        C++提供了關鍵字explicit,可以阻止不應該允許的經過轉換構造函數進行的隱式轉換的發生。聲明爲explicit的構造函數不能在隱式轉換中使用。

  C++中, 一個參數的構造函數, 承擔了兩個角色。 1 是個構造器 2 是個默認且隱含的類型轉換操作符。

  所以, 有時候在我們寫下如 AAA = XXX, 這樣的代碼, 且恰好XXX的類型正好是AAA單參數構造器的參數類型, 這時候編譯器就自動調用這個構造器, 創建一個AAA的對象。

  這樣看起來好象很酷, 很方便。 但在某些情況下(見下面權威的例子), 卻違背了我們(程序員)的本意。 真是成也蕭何, 敗也蕭何。 這時候就要在這個構造器前面加上explicit修飾, 指定這個構造器只能被明確的調用,使用, 不能作爲類型轉換操作符被隱含的使用。 呵呵, 看來還是光明正大些比較好。

explicit構造函數的作用
   explicit構造函數是用來防止隱式轉換的。

   請看下面的代碼:

 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 t3(12); //顯示調用成功

   return 0;

 }

Test1的構造函數帶一個int型的參數,代碼19行會隱式轉換成調用Test1的這個構造函數。而Test2的構造函數被聲明爲explicit(顯式),這表示不能通過隱式轉換來調用這個構造函數,因此代碼20行會出現編譯錯誤。

  普通構造函數能夠被隱式調用。而explicit構造函數只能被顯示調用。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章