c 语言中,操作数运算时会向操作数中更高的类型(更精确)转换. 当结果超出表达范围. 即使赋值时显式类型转换,结果还是会丢失 .
如 long a = 1228970369 (十位) 12亿
long b = 10000000 (八位) 1千万
那么 a * b 会超出 long (约42亿) 十位十进制数的表达范围 结果是不对的.
曾经尝试 long long result = a * b 结果也是不对的.要足够长,就得使参与运算的操作数中有
足够长的类型.因此解决方法是
long long result = a * (long long)b 或将转换放到 a 前面.
更深入的看这个问题,应该是编译器存放中间结果的时候会根据操作数来处理,而不是赋值给什么类型
一个赋值表达式最终是要拆成几条指令来执行的,赋值的操作在后面前面无法预测,(新的处理器设计有类似的处理).只能按照操作数的类型来存储了.
阅读(710) | 评论(0) | 转发(0) |