explicit构造函数的作用

本文深入探讨了C++中explicit构造函数的使用场景与限制,通过实例展示了如何防止隐式类型转换,并解释了普通构造函数与explicit构造函数之间的区别。通过具体代码演示,帮助开发者掌握构造函数的正确使用方式。
摘要由CSDN通过智能技术生成
explicit构造函数是用来防止隐式转换的。请看下面的代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
class  Test1
{
public :
     Test1( int  n)
     {
         num=n;
     } //普通构造函数
private :
     int  num;
};
class  Test2
{
public :
     explicit  Test2( int  n)
     {
         num=n;
     } //explicit(显式)构造函数
private :
     int  num;
};
int  main()
{
     Test1 t1=12; //隐式调用其构造函数,成功
     Test2 t2=12; //编译错误,不能隐式调用其构造函数
     Test2 t2(12); //显式调用成功
     return  0;
}
Test1的 构造函数带一个int型的参数,代码23行会隐式转换成调用Test1的这个构造函数。而Test2的构造函数被声明为explicit(显式),这表示不能通过隐式转换来调用这个构造函数,因此代码24行会出现编译错误。
普通构造函数能够被 隐式调用。而explicit构造函数只能被显式调用。

转载于:https://www.cnblogs.com/liyulong1982/p/5473139.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值