1、通过定义类型转换运算符,可以实现类类型的类型转换。转换构造函数和类型转换运算符共同定义了类类型转换,又称类型转换
2、构造函数可以实现其他类型向本类的转化,类型转换运算符可以实现本类向其它类型的转化
3、类型转换运算符是类的一种特殊成员函数,负责将一个类类型的值转换成其他类型,形式如下
其中,type可以是除void外的任何类型,只要该类型能作为函数的返回类型(返回的类型要与type一致);没有显式的返回类型,没有形参,而且必须定义为类的成员函数
由于不应改变待转换对象的内容,因此被定义为const成员
class Rational
{
private:
int zi, mu;
public:
operator double()const
{
return 1.0 * zi / mu;
}
};
4、类型转换运算符是隐式执行的,也就是说当遇到一些类未定义的行为时,会尝试类型转化,进而对转化后的内容进行操作
class Node
{
private:
int num;
public:
Node(){}
Node(int a)
{
num = a;
}
operator int()const
{
return num;
}
};
Node n;
n = 1; //4隐式转换成Node然后调用拷贝赋值运算符
n + 2; //Node隐式转换成int,然后执行整数加法
5、显式的类型转化运算符
为了防止隐式转化带来的不必要的麻烦,可以定义显示的类型转化运算符,此时不会自动调用类型转化
explicit operator int()const
{
return num;
}
(int)a + 1;
static_cast<int>(a) + 2;
6、如果表达式被用作条件,编译器将会显式的类型转化应用于它,有如下情况:
(1)、if、while、for及do语句的条件部分
(2)、逻辑非、逻辑与、逻辑或的运算对象
(3)、条件运算符的条件表达式
7、在IO标准库中,无论何时我们使用流对象,都会将IO类型转化为bool,如while(cin>>value)中,我们将数据读入value,然后cin被类型转化函数隐式转换为bool类型,如果读入成功返回真
8、如果类中包含一个或多个类型转换,必须确保类类型和目标类型只有唯一一种转换方式,否则将会产生二义性错误,可能有以下情况:
(1)、实参匹配和相同的类型转换:类A、B中,B有转化为A的类型转换运算符,A有以B为参数的构造函数
(2)、多个类型转换:类A中有转化为int、double的类型转换运算符
(3)、重载函数与转换构造函数:几个重载函数分属不同的类类型,而这些类恰好定义了同样的转换构造函数
9、重载的运算符也是重载的函数,因此通用的函数匹配规则也适用于调用内置还是重载函数