通过关键字explicit的作用,我么可以禁止“单参数构造函数”被用于自动型别转换。
典型的例子便是群集类别,你可以将初始长度作为参数传给构造函数,一下举个例子
class P
{
public:
explicit P(int x):y(x),str("ssss")
{
cout<<str<<endl;
}
P(const P &d)
{
y=d.y;
str=new char[strlen(d.str)+1];
if(d.str)
strcpy(str,d.str);
else
cout<<"为空"<<endl;
}
virtual void g()
{
cout<<"P 虚函数"<<endl;
cout<<str<<endl;
}
private:
int y;
char *str;
};
void main()
{
P t=5; //error
P t(5);
}
这时候编译器会报错:error C2440: 'initializing' : cannot convert from 'const int' to 'class P'
"自动型别转换"动作会把5转换为类型为含有5个元素的P,并指派给t。这是错误的。
如果在构造函数前没加explicit,P t=5 编译器不会报错,这就造成隐患。所以构造函数前最好加上explicit。