C++ explicit 關鍵字
explicit關鍵字在平時的編程應用中用到的不多,但是經常在一些源代碼中看到使用。而且還有C中的volatile這個關鍵字在面試筆試也經常看到。
explicit的意思是明顯的,和它相對應的一個詞是implicit意思是隱藏的。
參考了MSDN和《c++標準程序庫》對這個關鍵字的描述,並參考了網絡上對這個關鍵字的解釋。現將它的使用方法和總結記錄如下:
首先這個關鍵字只能用在類構造函數。它的作用是不能進行隱式轉換。
class gxgExplicit //沒有關鍵字explicit的類
{
public:
int _size;
gxgExplicit(int size)
{
_size = size;
}
};
下面是調用
gxgExplicit gE1(24); //這樣是沒有問題的
gxgExplicit gE2 = 1; //這樣也是沒有問題的
gxgExplicit gE3; //這樣是不行的,沒有默認構造函數
gE1 = 2; //這樣也是沒有問題的
gE2 = 3; //這樣也是沒有問題的
gE2 = gE1; //這樣也是沒有問題的
但是假如gxgExplicit修改爲Stack,我們的_size代表的是堆棧的大小,那麼調用的第二句就顯得不倫不類,而且容易讓人疑惑。這並不是可以讓代碼閱讀者明白和接受的形式,雖然它是合法的(編譯器可以通過編譯)。這是因爲編譯器默認情況下有隱式轉換的功能,你輸入gE2 = 1就編譯成同第一句相同的結果。所以,explicit就派上了用場。修改代碼爲:
class gxgExplicit
{
public:
int _size;
explicit gxgExplicit(int size)
{
_size = size;
}
};
繼續上面的調用:
gxgExplicit gE1(24); //這樣是沒有問題的
gxgExplicit gE2 = 1; //這樣是不行的,關鍵字取消了隱式轉換
gxgExplicit gE3; //這樣是不行的,沒有默認構造函數
gE1 = 2; //這樣是不行的,關鍵字取消了隱式轉換
gE2 = 3; //這樣是不行的,關鍵字取消了隱式轉換
gE2 = gE1; //這樣是不行的,關鍵字取消了隱式轉換,除非類實現操作符“=”的重載。
這是編譯器(vs2005)顯示:cannot convert from 'int' to 'gxgExplicit'。
從這裏也就看出這個關鍵字的作用是將編譯器隱式轉換的功能給屏蔽掉。
MSDN上有一個注意點描述了下面的事實,當構造函數參數超過兩個時自動取消隱式轉換。例如
class gxgExplicit
{
private:
int _size;
int _age;
public:
explicit gxgExplicit(int age, int size)
{
_age = age;
_size = size;
}
};
這是有沒有關鍵字效果是一樣的。那就是相當於有這個關鍵字。
但是另外一種情況例外:其中只有一個必須輸入的參數,其餘的爲有默認值的參數。
class gxgExplicit
{
private:
int _size;
int _age;
public:
explicit gxgExplicit(int age, int size = 0)
{
_age = age;
_size = size;
}
};
class gxgExplicit
{
private:
int _size;
int _age;
int _hight;
public:
explicit gxgExplicit(int age, int size = 0)
{
_age = age;
_size = size;
_hight = hight;
}
};
這樣的情況下相當於一個參數的效果。
簡單總結一下:
explicit只用於構造函數,
對於只有一個參數的構造函數,有沒有這explicit個關鍵字行爲不同。
對於多參數構造函數,其中只有一個必須輸入,其他參數有默認值,這種情況類似於上述只有一個參數的情況。
對於其他情況多參數構造函數,構造函數默認轉化爲explicit。