游泳

C++中的显式构造函数_a

2020-01-22 22:42:21来源:励志吧0次阅读

有如下一个简单的复数类:classClxComplex

{

public:

ClxComplex(doubledReal=0.0,doubledImage=0.0){m_dReal=dReal;dImage=dImage;}

doubleGetReal()const{returnm_dReal;}

doubleGetImage()const{returnm_dImage;}

private:

doublem_dReal;

doublem_dImage;

};

我们知道,下面的3行代码是等价的:

ClxComplexlxTest=2.0;

ClxComplexlxTest=ClxComplex(2.0);

ClxComplexlxTest=ClxComplex(2.0,0.0);

其实,对于前两行来说,编译器都是把它们转换成第3行的代码来实现的。因为我们写了构造函数,编译器就按照我们的构造函数来进行隐式转换,直接把一个double数值隐式转换成了一个ClxComplex的对象。可是,有些时候,我们不希望进行隐式转换,或者隐式转换会造成错误。比如下面的一个简化的字符串类:

classClxString

{

public:

ClxString(intiLength);

ClxString(constchar*pString);

~ClxString();

private:

char*m_pString;

};

ClxString::ClxString(intiLength)

{

if(iLength>0)

m_pString=newchar[iLength];

}

ClxString::ClxString(constchar*pString)

{

m_pString=newchar[strlen(pString)];

strcpy(m_pString,pString);

}

ClxString::~ClxString()

{

if(m_pString!=NULL)

deletem_pString;

}

我们可以用字符串的长度来初始化一个ClxString的对象,但是我们却不希望看到下面的代码:

ClxStringlxTest=13;//等同于ClxStringlxTest=ClxString(13);

这会给阅读代码造成不必要的歧义。

还有,我们知道下面的代码是用字符串A来初始化一个ClxString的对象:

ClxStringlxTest="A";//等同于ClxStringlxTest=ClxString("A");

可是,如果有人写成:

ClxStringlxTest="A";//等同于ClxStringlxTest=ClxString(65);

那上面的代码就会初始化一个长度为65(字母A的ASCII码值,在C和C++中,字符是以ASCII值存储的)的字符串。

当然,上面的情况都不是我们希望看到的。在这个时候我们就要用到显示构造函数了。

将构造函数声明成explicit就可以防止隐式转换。

下面是使用显示构造函数的ClxString:

classClxString

{

public:

explicitClxString(intiLength);

ClxString(constchar*pString);

~ClxString();

private:

char*m_pString;

};

在这种情况下,要想用字符串的长度来初始化一个ClxString对象,那就必须显示的调用构造函数:

ClxStringlxTest=ClxString(13);

而下面这些代码将不能通过编译。

ClxStringlxTest=13;

ClxStringlxTest="A";

动脉硬化并发症能用通心络胶囊治疗吗
汉森四磨汤怎么服用
动脉粥样硬化严重可以吃通心络吗
专为儿童研制的止咳药哪个效果好
分享到: