C++显式转换(4)-reinterpret_cast

来源:互联网 发布:java高并发问题 编辑:程序博客网 时间:2024/06/07 02:10

对于reinterpret_cast的认识,有些人会觉得它功能很强大,可以实现相当灵活的类型转换。但是我们更愿意说灵活就意味着高风险。


我们首先来考察下面的代码:


int number = 0x1234;

char* pc = reinterpret_cast<char*>(&number);


这段代码的目的是想将一个整数分解为几个字节,结果就保存在pc指向的字符型缓冲区中。这里并没有利用常用的移位操作,所以速度飞快。


但是,你认为pc[0],pc[1],pc[2],pc[3]分别等于多少呢?

答案是不一定,要想得到正确答案至少要考虑以下两个因素:


  1. int是16位还是32位?

  2. CPU是大端模式(Big-endian)还是小端模式(Little-endian)?


只有把这些都考虑清楚了,才有可能的到正确的结果。更不要说代码移植时会发生的问题了。想想就头疼。


reinterpret_cast本质上依赖机器。要想安全地使用reinterpret_cast,程序员必须对涉及的类型和编译器实现的转换过程都非常了解。--------C++Primer第五版


另一个说法是,没有免费的午餐。




阅读最新文章请扫描下面二维码,关注公众号【面向对象思考】。



0 0
原创粉丝点击