这个论题来自今天我在segmentfault的回复。
有我的问segmentfault
《C++ Primer》第五版,中文版。p33。
1.999999999999999(比转换以后少是 2 的少个 9) 也是 1。编辑器
微软免费 IDE 2015。g++ 好像也同样。学习
#include using namespace std; int main() { double d = 1.9999999999999999; int i = d; cout
呐,若是你C语言学习的足够牢靠的话,你应该知道double型的精度是小数点后15位,而若是你写了16位的话,编译器会认为你输入的值无效,而自动帮你转换为2.0。
而根据浮点型转整形的指令规范,1.x转换后均为1,相似的,2.0天然为2。优化
实质上,你本身写个程序,而后右键汇编就能够看出来了,很是简单的问题。
我再补充下汇编代码就更加清楚了。spa
15个9的时候,编译后的代码中此处的值为 0x3ffffffffffffffb
code
16个9的时候,编译后的代码直接就是 0x4000000000000000
,即2.0blog
即,这一过程是由编辑器进行的优化而已。get