一个double可以很容易的转换成int,我们的类与类之间自然也可以进行转换,转换构造函数和类型转换运算符共同定义了类类型转换,这样的转换有时也被称作用户定义的类型转换。
类型转换运算符
下面是一个定义了类型转换运算符的类
class example{
public:
example(int i=0):a(i){
if (i<0) throw std::out_of_range("bad unsigned int");};
operator int() const{
return a;}//类型转换描述符
private:
unsigned int a=0;
}
构造函数讲一个int类型转换为类类型,而类型转换描述符将类类型转换为一个int型。
调用
example s=4;
s+3//将s转换为int,再执行整数加法
example p=1.1;//先将1.1转换为double,再调用了example(int)构造函数
需要注意的是:
1.编译器一次只能执行一个用户执行的成员函数,但是隐式的用户定义类型转换可以置于一个内置的类型转换之前之后。也就是说,我们将任何一个算数类型交example的构造函数后,它可以先执行内置转换成int型,再调用构造函数从int型转换成example型。
2.因为类型转换运算符是隐式执行的,所以我们无法给这些函数传递实参,也无法使用实参的值。
3.虽然一个类型转换描述没有指定返回值,但实际上还是需要返回一个指定类型的值。
二义性调用
实参匹配且进行相同的类型转换
//以下只是举例子用
class A{
A(const B&); //将B转换成A
}
class B{
operator A() const;将B转换成A
}
A f(const A&);
B b;
A a=f(b);//此时存在两种调用一种是A::const B& 另一种是B::operator A()
转换目标为内置类型的多重类型转换
class A{
operator long() const;
operator double()const;
}
void f(long double);
A a;
f(a)//由于a可同时向long和double转化,同时long和double向long double转换的优先级相同。所以出现二义性调用。
//此时当我们调用 A(int)