c++ - 关于 C++ 中 double 和 int 之间转换的奇怪结果

标签 c++ c type-conversion

我的问题:

尝试找出以下 C++ 片段的结果:

#include <iostream>

int main(int argc, char* argv[])
{
    double a = 5.1;
    int b = a * 100;
    std::cout << b << std::endl;

    double c = 6.1;
    int d = c * 100;
    std::cout << d << std::endl;
}

在 Windows 上,我用 VS2008 SP1 编译并运行上面的代码,得到:

509
610

在 Linux 上,我使用 g++ 编译并运行了相同的代码并得到:

509
609

代码有什么问题?

抱歉,我试图为该问题找出一个标题,因此我可以四处搜索。不过这个问题我说不上来,所以直接在这里提出来。

如有任何建议,我们将不胜感激。

最佳答案

double 不是精确类型,正如您通过应用 std::numeric_limits typetrait 可以看到的那样:

#include <limits>

static_assert(std::numeric_limits<double>::is_exact == false);

因此涉及 double 的计算只是近似值,您观察到的结果没有错。

您的代码没有问题。

关于c++ - 关于 C++ 中 double 和 int 之间转换的奇怪结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12353616/

相关文章:

c++ - 尝试构建示例代码时出现编译错误

c - 编写打印人类可读时间的内核系统调用

r - 导入不带千位分隔符的 csv 并将因子转换为数字,而不会丢失小数点分隔符

c++ - 程序没有返回指定值?

c++ - std::vector 的正确分配

c - CUDA 内联汇编从 GAS 到 Intel 的翻译

c - OpenGL 加载多个纹理 - 不工作

c++ - 如何从 BYTE* 转换为 QString?

java - 使用java解压二进制php packed float

c++ - 异常消息为空