C++11常用语法- explicit类型转换运算符的具体用法
为了想explicit类型转换运算符和C++Primer书中不同的地方,且提供更加有意义的例子,作者花费了不少心思,请大家务必认真理解。
类型转换运算符
看下面的例子:
这时一个复数类的雏形,定义了一个double类型的类型转换运算符。有了它以后,可以像下面这样使用:
输出结果如下:
complex不支持输出运算符,所以编译器努力将c1转换成double类型以后输出。到目前为止都挺好。
真的是想转换成double?
再看下面的代码:
如果从数学的角度来讲,应该输出2.23606。但实际上,这段代码连编译都通不过。其原因是对于这段代码编译器有两种选择:一个是将c1转换称double然后加1;另一个是将1转换为复数(1+0i)以后执行复数加法。
需要程序员给个想法。
显式的类型转换运算符
为了消除二义性,一个办法就是使用explicit禁止隐式的double类型转换。代码如下:
由于无法进行隐式类型转换,所以下面的代码会出现编译错误:
这并不是什么大问题,因为转换为double输出这件事本身对不对都不好讲。代码中已经通过输出运算符重载提供了复数形式的输出功能。
输出如下:
这才是我们真正想要的!
补充一点
如果愿意的话,也可以这样编码:
觉得本文有帮助?请分享给更多人。
相关推荐:
HTML 运算符、类型转换
C# 自定义 implicit和explicit转换
C 语言教程
以上就是C++11常用语法- explicit类型转换运算符的具体用法的详细内容,更多请关注其它相关文章!