C++之显示构造函数
有如下一個簡單的復數(shù)類:
class ClxComplex { public:ClxComplex(double dReal = 0.0, double dImage = 0.0) { m_dReal = dReal; dImage = dImage; }double GetReal() const { return m_dReal; }double GetImage() const { return m_dImage; }private:double m_dReal;double m_dImage; };我們知道,下面的3行代碼是等價的:
ClxComplex?lxTest?=?2.0;
ClxComplex?lxTest?=?ClxComplex(2.0);
ClxComplex?lxTest?=?ClxComplex(2.0,?0.0);
其實,對于前兩行來說,編譯器都是把它們轉(zhuǎn)換成第3行的代碼來實現(xiàn)的。因為我們寫了構(gòu)造函數(shù),編譯器就按照我們的構(gòu)造函數(shù)來進行隱式轉(zhuǎn)換,直接把一個double數(shù)值隱式轉(zhuǎn)換成了一個ClxComplex的對象??墒?#xff0c;有些時候,我們不希望進行隱式轉(zhuǎn)換,或者隱式轉(zhuǎn)換會造成錯誤。比如下面的一個簡化的字符串類:
class ClxString { public:ClxString(int iLength);ClxString(const char *pString);~ClxString();private:char *m_pString; };ClxString::ClxString(int iLength) {if (iLength > 0)m_pString = new char[iLength]; }ClxString::ClxString(const char *pString) {m_pString = new char[strlen(pString)];strcpy(m_pString, pString); }ClxString::~ClxString() {if (m_pString != NULL)delete m_pString; }我們可以用字符串的長度來初始化一個ClxString的對象,但是我們卻不希望看到下面的代碼:
ClxString?lxTest?=?13;??//?等同于ClxString?lxTest?=?ClxString(13);
這會給閱讀代碼造成不必要的歧義。
還有,我們知道下面的代碼是用字符串A來初始化一個ClxString的對象:
ClxString?lxTest?=?"A";??//?等同于ClxString?lxTest?=?ClxString("A");
可是,如果有人寫成:
ClxString?lxTest?=?'A';??//?等同于ClxString?lxTest?=?ClxString(65);
那上面的代碼就會初始化一個長度為65(字母A的ASCII碼值,在C和C++中,字符是以ASCII值存儲的)的字符串。
當然,上面的情況都不是我們希望看到的。在這個時候我們就要用到顯示構(gòu)造函數(shù)了。
將構(gòu)造函數(shù)聲明成explicit就可以防止隱式轉(zhuǎn)換。
下面是使用顯示構(gòu)造函數(shù)的ClxString:
在這種情況下,要想用字符串的長度來初始化一個ClxString對象,那就必須顯示的調(diào)用構(gòu)造函數(shù):
ClxString?lxTest?=?ClxString(13);
?而下面這些代碼將不能通過編譯:
ClxString?lxTest?=?13;?
ClxString?lxTest?=?'A';
總結(jié)
以上是生活随笔為你收集整理的C++之显示构造函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++ 之类的静态成员
- 下一篇: QT 中 关键字讲解(emit,sign