c++ - 为什么 1.999(共16个9) 转换成 int 是 2,1.9 转换成 int 是 1?
怪我咯
怪我咯 2017-04-17 13:46:37
[C++讨论组]

《C++ Primer》第五版,中文版。p33。
1.999999999999999(比转换之后少是 2 的少个 9) 也是 1。
微软免费 IDE 2015。g++ 好像也一样。

#include <iostream>
using namespace std;

int main()
{
    double d = 1.9999999999999999;
    int i = d;
    cout << i << endl;

    return 0;
}
怪我咯
怪我咯

走同样的路,发现不同的人生

全部回复(2)
大家讲道理

呐,如果你C语言学习的足够牢靠的话,你应该知道double型的精度是小数点后15位,而如果你写了16位的话,编译器会认为你输入的值无效,而自动帮你转换为2.0。
而根据浮点型转整形的指令规范,1.x转换后均为1,类似的,2.0自然为2。

补充

实质上,你自己写个程序,然后右键汇编就可以看出来了,非常简单的问题。
我再补充下汇编代码就更加清楚了。

  1. 15个9的时候,编译后的代码中此处的值为0x3ffffffffffffffb

  2. 16个9的时候,编译后的代码直接就是0x4000000000000000,即2.0

即,这一过程是由编辑器进行的优化而已。

高洛峰

因为这个

#include <iostream>
using namespace std;

int main()
{
    double d = 1.9999999999999999;
    int i = d;
    cout <<"d = "<< d<<"\ni = "<< i << endl;

    return 0;
}

你运行一下,看看输出什么。
因为浮点数并不是能精确表示所有的数,有些数只能是保存的近似值。这里的1.9999999999999999,就会保存其近似值2。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号