explicit

C++中, 一個參數的構造函數(或者除了第一個參數外其餘參數都有默認值的多參構造函數), 承擔了兩個角色。 1 是個構造器 ,2 是個默認且隱含的類型轉換操作符。
所以, 有時候在我們寫下如 AAA = XXX, 這樣的代碼, 且恰好XXX的類型正好是AAA單參數構造器的參數類型, 這時候編譯器就自動調用這個構造器, 創建一個AAA的對象。
這樣看起來好象很酷, 很方便。 但在某些情況下(見下面權威的例子), 卻違背了我們(程序員)的本意。 這時候就要在這個構造器前面加上explicit修飾, 指定這個構造器只能被明確的調用,使用, 不能作爲類型轉換操作符被隱含的使用。 呵呵, 看來還是光明正大些比較好。
explicit構造函數的作用
解析:
explicit構造函數是用來防止隱式轉換的。請看下面的代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
classTest1
{
public:
    Test1(intn) { num = n; } //普通構造函數
private:
    intnum;
};
classTest2
{
public:
    explicitTest2(intn) { num = n; } //explicit(顯式)構造函數
private:
    intnum;
};
int main()
{
    Test1 t1 = 12; //隱式調用其構造函數, 成功
    Test2 t2 = 12; //編譯錯誤,不能隱式調用其構造函數
    Test2 t3(12); //顯式調用成功
    return0;
}
Test1的構造函數帶一個int型的參數,代碼17行會隱式轉換成調用Test1的這個構造函數。而Test2的構造函數被聲明爲explicit(顯式),這表示不能通過隱式轉換來調用這個構造函數,因此代碼18行會出現編譯錯誤。
普通構造函數能夠被隱式調用。而explicit構造函數只能被顯示調用。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章