这篇文章主要介绍“C++11中explicit类型转换运算符的实例用法”,在日常操作中,相信很多人在C++11中explicit类型转换运算符的实例用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++11中explicit类型转换运算符的实例用法”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
类型转换运算符
看下面的例子:
这时一个复数类的雏形,定义了一个double类型的类型转换运算符。有了它以后,可以像下面这样使用:
输出结果如下:
complex不支持输出运算符,所以编译器努力将c1转换成double类型以后输出。到目前为止都挺好。
真的是想转换成double?
再看下面的代码:
如果从数学的角度来讲,应该输出2.23606。但实际上,这段代码连编译都通不过。其原因是对于这段代码编译器有两种选择:一个是将c1转换称double然后加1;另一个是将1转换为复数(1+0i)以后执行复数加法。
需要程序员给个想法。
显式的类型转换运算符
为了消除二义性,一个办法就是使用explicit禁止隐式的double类型转换。代码如下:
由于无法进行隐式类型转换,所以下面的代码会出现编译错误:
这并不是什么大问题,因为转换为double输出这件事本身对不对都不好讲。代码中已经通过输出运算符重载提供了复数形式的输出功能。
输出如下:
到此,关于“C++11中explicit类型转换运算符的实例用法”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。