天天看點

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構造函數隻能被顯示調用。 隐式轉換常常帶來程式邏輯的錯誤,而且這種錯誤一旦發生是很難察覺的。

繼續閱讀