C++中的explicitkeyword
生活随笔
收集整理的這篇文章主要介紹了
C++中的explicitkeyword
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
在C++程序中非常少有人去使用explicitkeyword,不可否認(rèn),在平時的實踐中確實非常少能用的上。再說C++的功能強(qiáng)大,往往一個問題能夠利用好幾種C++特性去解決。但略微留心一下就會發(fā)現(xiàn)現(xiàn)有的MFC庫或者C++標(biāo)準(zhǔn)庫中的相關(guān)類聲明中explicit出現(xiàn)的頻率是非常高的。了解explicitkeyword的功能及其使用對于我們閱讀使用庫是非常有幫助的,并且在編寫自己的代碼時也能夠嘗試使用。既然C++語言提供這樣的特性,我想在有些時候這樣的特性將會非常實用。 按默認(rèn)規(guī)定,僅僅用傳一個參數(shù)的構(gòu)造函數(shù)也定義了一個隱式轉(zhuǎn)換。舉個樣例: (以下這個CExample沒有什么實際的意義,主要是用來說明問題) //Example.h #pragma once class CExample { public: CExample(void); public: ~CExample(void); - public: int m_iFirst; int m_iSecond; public: CExample(int iFirst, int iSecond = 4); }; //Example.cpp #include "StdAfx.h" #include "Example.h" CExample::CExample(void) : m_iFirst(0) { } CExample::~CExample(void) { } CExample::CExample(int iFirst, int iSecond):m_iFirst(iFirst), m_iSecond(iSecond) { } //TestExplicitKey.cpp ...//其他頭文件 #include "Example.h" int _tmain(int argc, _TCHAR* argv[]) { CExample objOne; //調(diào)用沒有參數(shù)的構(gòu)造函數(shù) CExample objTwo(12, 12); //調(diào)用有兩個參數(shù)的構(gòu)造函數(shù) CExample objThree(12); //同上,能夠傳一個參數(shù)是由于該構(gòu)造函數(shù)的第二個參數(shù)有默認(rèn)值 CExample objFour = 12; //運行了隱式轉(zhuǎn)換,等價于CExample temp(12);objFour(temp);注意這個地方調(diào)用了 //編譯器為我們提供的默認(rèn)復(fù)制構(gòu)造函數(shù) return 0; } 假設(shè)在構(gòu)造函數(shù)聲明中添�keywordexplicit,例如以下 explicit CExample(int iFirst, int iSecond = 4); 那么CExample objFour = 12; 這條語句將不能通過編譯。在vs05下的編譯錯誤提演示樣例如以下 error C2440: 'initializing' : cannot convert from 'int' to 'CExample' Constructor for class 'CExample' is declared 'explicit' 對于某些類型,這一情況很理想。但在大部分情況中,隱式轉(zhuǎn)換卻easy導(dǎo)致錯誤(不是語法錯誤,編譯器不會報錯)。隱式轉(zhuǎn)換總是在我們沒有察覺的情況下悄悄發(fā)生,除非有心所為,隱式轉(zhuǎn)換經(jīng)常是我們所不希望發(fā)生的。通過將構(gòu)造函數(shù)聲明為explicit(顯式)的方式能夠抑制隱式轉(zhuǎn)換。也就是說,explicit構(gòu)造函數(shù)必須顯式調(diào)用。 引用一下Bjarne Stroustrup的樣例: class String{ explicit String(int n); String(const char *p); }; String s1 = 'a'; //錯誤:不能做隱式char->String轉(zhuǎn)換 String s2(10);?? //能夠:調(diào)用explicit String(int n); String s3 = String(10);//能夠:調(diào)用explicit String(int n);再調(diào)用默認(rèn)的復(fù)制構(gòu)造函數(shù) String s4 = "Brian"; //能夠:隱式轉(zhuǎn)換調(diào)用String(const char *p);再調(diào)用默認(rèn)的復(fù)制構(gòu)造函數(shù) String s5("Fawlty"); //能夠:正常調(diào)用String(const char *p); void f(String); - String g() { f(10); //錯誤:不能做隱式int->String轉(zhuǎn)換 f("Arthur"); //能夠:隱式轉(zhuǎn)換,等價于f(String("Arthur")); return 10; //同上 } 在實際代碼中的東西可不像這樣的有益造出的樣例。 發(fā)生隱式轉(zhuǎn)換,除非有心利用,隱式轉(zhuǎn)換經(jīng)常帶來程序邏輯的錯誤,并且這樣的錯誤一旦發(fā)生是非常難察覺的。 原則上應(yīng)該在全部的構(gòu)造函數(shù)前加explicitkeyword,當(dāng)你有心利用隱式轉(zhuǎn)換的時候再去解除explicit,這樣能夠大大降低錯誤的發(fā)生。 -
轉(zhuǎn)載于:https://www.cnblogs.com/hrhguanli/p/3905614.html
總結(jié)
以上是生活随笔為你收集整理的C++中的explicitkeyword的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 瓜娃子给人送刀,不摆明一刀两断嘛~~~?
- 下一篇: Effective STL 为包含指针的