隐式转换

隐式转换

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

禁止隐式转换

explicit构造函数是用来防止隐式转换的。请看下面的代码:
 1 class Test1
 2 {
 3     public:
 4     Test1(int n) { num = n; } //普通构造函数
 5     private:
 6     int num;
 7 };
 8 
 9 class Test2
10 {
11     public:
12         explicit Test2(int n) { num = n; } //explicit(显式)构造函数
13     private:
14         int num;
15 };
16 
17 int main()
18 {
19     Test1 t1 = 12; //隐式调用其构造函数, 成功
20     Test2 t2 = 12; //编译错误,不能隐式调用其构造函数
21     Test2 t3(12); //显式调用成功
22     return 0;
23 }
View Code
Test1的构造函数带一个int型的参数,代码19行会隐式转换成调用Test1的这个构造函数。而Test2的构造函数被声明为explicit(显式),这表示不能通过隐式转换来调用这个构造函数,因此代码20行会出现编译错误。
普通构造函数能够被隐式调用。而explicit构造函数只能被显示调用。
 
 

 

转载于:https://www.cnblogs.com/TaoyzDream/p/3688326.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值