explicit
C++提供了關鍵字explicit,可以阻止不應該允許的經過轉換構造函數進行的隱式轉換的發生。聲明爲explicit的構造函數不能在隱式轉換中使用。
C++中, 一個參數的構造函數, 承擔了兩個角色。 1 是個構造器 2 是個默認且隱含的類型轉換操作符。
所以, 有時候在我們寫下如 AAA = XXX, 這樣的代碼, 且恰好XXX的類型正好是AAA單參數構造器的參數類型, 這時候編譯器就自動調用這個構造器, 創建一個AAA的對象。
這樣看起來好象很酷, 很方便。 但在某些情況下(見下面權威的例子), 卻違背了我們(程序員)的本意。 真是成也蕭何, 敗也蕭何。 這時候就要在這個構造器前面加上explicit修飾, 指定這個構造器只能被明確的調用,使用, 不能作爲類型轉換操作符被隱含的使用。 呵呵, 看來還是光明正大些比較好。
explicit構造函數的作用
解析:
explicit構造函數是用來防止隱式轉換的。請看下面的代碼:
1 class Test1
2 {
3 public:
4 Test1(int n) { num = n; } //普通構造函數
5 private:
6 int num;
7 };
8
9 class Test2
10 {
11 public:
12 explicit Test2(int n) { num = n; } //explicit(顯式)構造函數
13 private:
14 int num;
15 };
16
17 int main()
18 {
19 Test1 t1 = 12; //隱式調用其構造函數, 成功
20 Test2 t2 = 12; //編譯錯誤,不能隱式調用其構造函數
21 Test2 t3(12); //顯示調用成功
22 return 0;
23 }
Test1的構造函數帶一個int型的參數,代碼19行會隱式轉換成調用Test1的這個構造函數。而Test2的構造函數被聲明爲explicit(顯式),這表示不能通過隱式轉換來調用這個構造函數,因此代碼20行會出現編譯錯誤。
普通構造函數能夠被隱式調用。而explicit構造函數只能被顯示調用。
C++中, 一個參數的構造函數, 承擔了兩個角色。 1 是個構造器 2 是個默認且隱含的類型轉換操作符。
所以, 有時候在我們寫下如 AAA = XXX, 這樣的代碼, 且恰好XXX的類型正好是AAA單參數構造器的參數類型, 這時候編譯器就自動調用這個構造器, 創建一個AAA的對象。
這樣看起來好象很酷, 很方便。 但在某些情況下(見下面權威的例子), 卻違背了我們(程序員)的本意。 真是成也蕭何, 敗也蕭何。 這時候就要在這個構造器前面加上explicit修飾, 指定這個構造器只能被明確的調用,使用, 不能作爲類型轉換操作符被隱含的使用。 呵呵, 看來還是光明正大些比較好。
explicit構造函數的作用
解析:
explicit構造函數是用來防止隱式轉換的。請看下面的代碼:
1 class Test1
2 {
3 public:
4 Test1(int n) { num = n; } //普通構造函數
5 private:
6 int num;
7 };
8
9 class Test2
10 {
11 public:
12 explicit Test2(int n) { num = n; } //explicit(顯式)構造函數
13 private:
14 int num;
15 };
16
17 int main()
18 {
19 Test1 t1 = 12; //隱式調用其構造函數, 成功
20 Test2 t2 = 12; //編譯錯誤,不能隱式調用其構造函數
21 Test2 t3(12); //顯示調用成功
22 return 0;
23 }
Test1的構造函數帶一個int型的參數,代碼19行會隱式轉換成調用Test1的這個構造函數。而Test2的構造函數被聲明爲explicit(顯式),這表示不能通過隱式轉換來調用這個構造函數,因此代碼20行會出現編譯錯誤。
普通構造函數能夠被隱式調用。而explicit構造函數只能被顯示調用。