c - 为什么系统之间打印的位数不同?

标签 c gcc printf llvm

我使用的是 OS X,其版本为 i686-apple-darwin11-llvm-gcc-4.2 (GCC) 4.2.1(基于 Apple Inc. build 5658)(LLVM build 2336.11.00)在 Windows 7 上使用 gcc (tdm64-1) 4.6.1

为什么以下代码在两个系统上生成不同的输出:

double d = 2.71828152557319224769116772222332656383514404296875;
printf("%1.55f\n", d);

OS X 输出为 2.7182815255731922476911677222233265638351440429687500000

Win7输出为2.7182815255731922000000000000000000000000000000000000000

sizeof(double) == 8 在两个系统上。

最佳答案

C 标准不要求 printf 打印实际值,只要求其正确到一定数量的位置并满足某些舍入方向误差约束。大多数类 UNIX 操作系统都会打印精确值,或者如果没有足够的位置来打印精确值,则将值正确舍入到所请求的位数。 MSVCRT 舍入到固定数量的位置,并用零填充其余部分。两种行为都很符合,但后者确实丑陋且低质量。

关于c - 为什么系统之间打印的位数不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13486544/

相关文章:

c - C程序初始化中反斜杠有什么用?

c - Fork() 未在父进程中返回 id > 0

c - 通过函数调用了解简单 C 程序的 x86-64 汇编

c++ - 使用 mingw 在每个新库或可执行文件中重新初始化本地静态对象

c - 格式化输出列表

c - 执行排序和搜索 C 函数时出错

在 GTK+ gui 中调用外部函数

gcc - 从 gcc 源构建 libada

C++ 检查返回码

c - 如何在 sprintf() 中获取追加模式