对于reinterpret_cast的认识,有些人会觉得它功能很强大,可以实现相当灵活的类型转换。但是我们更愿意说灵活就意味着高风险。
我们首先来考察下面的代码:
int number = 0x1234;
char* pc = reinterpret_cast<char*>(&number);
这段代码的目的是想将一个整数分解为几个字节,结果就保存在pc指向的字符型缓冲区中。这里并没有利用常用的移位操作,所以速度飞快。
但是,你认为pc[0],pc[1],pc[2],pc[3]分别等于多少呢?
答案是不一定,要想得到正确答案至少要考虑以下两个因素:
int是16位还是32位?
CPU是大端模式(Big-endian)还是小端模式(Little-endian)?
只有把这些都考虑清楚了,才有可能的到正确的结果。更不要说代码移植时会发生的问题了。想想就头疼。
reinterpret_cast本质上依赖机器。要想安全地使用reinterpret_cast,程序员必须对涉及的类型和编译器实现的转换过程都非常了解。--------C++Primer第五版
另一个说法是,没有免费的午餐。
阅读最新文章请扫描下面二维码,关注公众号【面向对象思考】。
转载请注明原文地址: https://ju.6miu.com/read-14910.html