0
点赞
收藏
分享

微信扫一扫

C++11新特性(55)- explicit类型转换运算符


为了想出本文中这个和C++Primer书中不同的,更加有意义的例子,作者花费了不少心思,请大家务必认真理解。

类型转换运算符

看下面的例子:

C++11新特性(55)- explicit类型转换运算符_运算符

 

这时一个复数类的雏形,定义了一个double类型的类型转换运算符。有了它以后,可以像下面这样使用:

C++11新特性(55)- explicit类型转换运算符_运算符_02

输出结果如下:

 

C++11新特性(55)- explicit类型转换运算符_C_03

 

complex不支持输出运算符,所以编译器努力将c1转换成double类型以后输出。到目前为止都挺好。

 

真的是想转换成double?

 

再看下面的代码:

C++11新特性(55)- explicit类型转换运算符_类型转换_04

C++11新特性(55)- explicit类型转换运算符_C_05

 

如果从数学的角度来讲,应该输出2.23606。但实际上,这段代码连编译都通不过。其原因是对于这段代码编译器有两种选择:一个是将c1转换称double然后加1;另一个是将1转换为复数(1+0i)以后执行复数加法。

 

需要程序员给个想法。

 

显式的类型转换运算符

 

为了消除二义性,一个办法就是使用explicit禁止隐式的double类型转换。代码如下:

C++11新特性(55)- explicit类型转换运算符_double类型_06

由于无法进行隐式类型转换,所以下面的代码会出现编译错误:

C++11新特性(55)- explicit类型转换运算符_类型转换_07

 

这并不是什么大问题,因为转换为double输出这件事本身对不对都不好讲。代码中已经通过输出运算符重载提供了复数形式的输出功能。

 

输出如下:

C++11新特性(55)- explicit类型转换运算符_C_08

 

这才是我们真正想要的!

 

补充一点

 

如果愿意的话,也可以这样编码:

 

C++11新特性(55)- explicit类型转换运算符_运算符_09

 

 

觉得本文有帮助?请分享给更多人。

阅读更多更新文章,关注微信公众号【面向对象思考】

C++11新特性(55)- explicit类型转换运算符_类型转换_10

举报

相关推荐

0 条评论