知道c++中有explicit關鍵字,但對其用法和作用的理解有些模糊,今天有時間給系統的澄清一下:
explicit關鍵字用來修飾類的建構函式,表明建構函式是顯示的,相對的是implicit關鍵字。首先這個關鍵字只能用在類內部的建構函式宣告上,而不能用在類外部的函式定義上,它的作用是不能進行隱式轉換。
用法**如下:
class cperson
private:
int m_height;//身高
};int _tmain(int argc, _tchar* argv)
cperson person2 = 175;這行**正確,這是因為編譯器預設情況下有隱式轉換的功能,把其轉換為cperson person2(175);如果不允許這種形式的轉換,那麼explicit關鍵字就派上用場了。
class cperson
private:
int m_height;//身高
};int _tmain(int argc, _tchar* argv)
此時,再次編譯的話,編譯器會提示錯誤:error c2440: 「初始化」: 無法從「int」轉換為「cperson」 class「cperson」的建構函式宣告為「explicit」,從錯誤提示可以看出,這個關鍵字的作用就是將編譯器隱式轉換功能給遮蔽掉。
例外:當建構函式有2個以上的引數時,自動取消隱式轉換,但有一種情況例外,構造函式引數有預設值,示例**如下:
class cperson
private:
int m_height;//身高
int m_weight;//體重
};int _tmain(int argc, _tchar* argv)
c explicit 關鍵字解析
c 提供了關鍵字explicit,可以阻止不應該允許的經過轉換建構函式進行的隱式轉換的發生。宣告為explicit的建構函式不能在隱式轉 換中使用。c 中,乙個引數的建構函式,承擔了兩個角色。1 是個構造器 2 是個預設且隱含的型別轉換操作符。所以,有時候在我們寫下如 aaa 這樣的 且恰好 的型別...
C explicit 關鍵字解析
c 提供了關鍵字explicit,可以阻止不應該允許的經過轉換建構函式進行的隱式轉換的發生。宣告為explicit的建構函式不能在隱式轉換中使用。c 中,乙個引數的建構函式,承擔了兩個角色。1 是個構造器 2 是個預設且隱含的型別轉換操作符。所以,有時候在我們寫下如 aaa 這樣的 且恰好 的型別正...
C explicit關鍵字詳解
首先,c 中的explicit關鍵字只能用於修飾只有乙個引數的類建構函式,它的作用是表明該建構函式是顯示的,而非隱式的,跟它相對應的另乙個關鍵字是implicit,意思是隱藏的,類建構函式預設情況下即宣告為implicit 隱式 那麼顯示宣告的建構函式和隱式宣告的有什麼區別呢?我們來看下面的例子 c...