C++类中的隐式类型转换 出现于构造函数,而且是单形参(并非指只有一个参数,是指其他参数有默认值,有可能出现只输入一个形参)
- 可以使用一个实参进行调用,不是指构造函数只能有一个形参。
- 隐式类类型转换容易引起错误,除非你有明确理由使用隐式类类型转换,否则,将可以用一个实参进行调用的构造函数都声明为explicit。
- explicit只能用于类内部构造函数的声明。它虽然能避免隐式类型转换带来的问题,但需要用户能够显式创建临时对象(对用户提出了要求)
#include <iostream>
using namespace std;
class Base
{
public:
int i;
Base(int x)
{
i = x;
}
void print(Base B)
{
cout <<"i= "<<B.i<< endl;
}
};
int main()
{
Base B(1);
B.printf(B);//正常情况下只能将Base类对象放入参数
B.print(3); //但是因为Base类的构造函数就一个参数,
//所以只输入一个参数时,可以隐式转换成Base类的对象,Base(3)
return 0;
}
前提:构造函数就一个形参
在构造函数前添加
explicit 可以预防隐式转换