C++中, 一个参数的
构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数), 承担了两个角色。 1 是个
构造器 ,2 是个默认且隐含的类型转换操作符。(注:只能修饰单个参数的构造函数或者除了第一个参数外其他参数都有默认值的多参构造函数)
所以, 有时候在我们写下如 AA = BB, 这样的代码, 且恰好BB的类型正好是AA单参数构造器的参数类型, 这时候
编译器就自动调用这个构造器, 创建一个AAA的对象。
在某些情况下, 却违背了我们(程序员)的本意。 这时候就要在这个构造器前面加上explicit修饰, 指定这个构造器只能被明确的调用/使用, 不能作为类型转换操作符被隐含的使用。
explicit构造函数是用来防止隐式转换的。请看下面的代码:
class
A
{
public
:
A(
int
n)
{
num=n;
}
//普通构造函数
private
:
int
num;
};
class
B
{
public
:
explicit
B(
int
n)
{
num=n;
}
//explicit(显式)构造函数
private
:
int
num;
};
int
main()
{
A a=12;
//隐式调用其构造函数,成功
B b1=12;
//编译错误,不能隐式调用其构造函数
B b2(12);
//显式调用成功
return
0;
}