关于explicit的应用

什么是explicit呢?很简单,他就是一个让隐式格式转换失效的关键字。

C++提供了关键字explicit,可以阻止不应该允许的经过转换构造函数进行的隐式转换的发生。声明为explicit的构造函数不能在隐式转换中使用。

下面解释一下:

explicit Student(const std::string & s):name(s),scores(){}
explicit Student(int n):name("NULLY"),scores(n){}

我以前提到过,可以用一个参数调用的勾走函数将用作从参数类型到类类型的隐式转换函数;但这通常不是好主意。在上述的第二个构造函数中,第一个参数表示数组元素的个数,不是数组中的值,因此,将一个构造函数用作int到Student的转换函数式没有意义的,所以使用explicit关闭隐式转换。如果省略了该关键字,则可以编写如下的代码:

Student doh("homer",10);
doh=5;
在这里,马虎的程序员键入的doh而不是doh[0],如果构造函数省略了explicit,则将使用构造函数调用Student(5)将5转换为一个临时Student对象,并使用“NULLY”来设置成员name的值,因此赋值操作将使用临时对象替换原来的doh值,使用exolicit后,编译器将认为上述赋值运算符是错误的。

下面是百度百科中的解释:

C++中, 一个参数的构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数), 承担了两个角色。 1 是个构造器 ,2 是个默认且隐含的类型转换操作符。
所以, 有时候在我们写下如 AAA = XXX, 这样的代码, 且恰好XXX的类型正好是AAA单参数构造器的参数类型, 这时候编译器就自动调用这个构造器, 创建一个AAA的对象。
这样看起来好象很酷, 很方便。 但在某些情况下(见下面权威的例子), 却违背了我们(程序员)的本意。 这时候就要在这个构造器前面加上explicit修饰, 指定这个构造器只能被明确的调用,使用, 不能作为类型转换操作符被隐含的使用。 呵呵, 看来还是光明正大些比较好。
explicit构造函数的作用
解析:
explicit构造函数是用来防止隐式转换的。请看下面的代码:

classTest1
{
public:
Test1(intn){num=n;}//普通构造函数
private:
intnum;
};
classTest2
{
public:
explicitTest2(intn){num=n;}//explicit(显式)构造函数
private:
intnum;
};
intmain()
{
Test1t1=12;//隐式调用其构造函数,成功
Test2t2=12;//编译错误,不能隐式调用其构造函数
Test2t3(12);//显式调用成功
return0;
}

Test1的构造函数带一个int型的参数,代码17行会隐式转换成调用Test1的这个构造函数。而Test2的构造函数被声明为explicit(显式),这表示不能通过隐式转换来调用这个构造函数,因此代码18行会出现编译错误。
普通构造函数能够被隐式调用。而explicit构造函数只能被显式调用。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值