我在OS X上使用i686-apple-darwin11-llvm-gcc-4.2 (GCC) 4.2.1 (Based on 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
。
答案 0 :(得分:4)
C标准不要求printf
打印实际值,只要它能够达到一定数量的位置并满足某些舍入方向误差约束。如果没有足够的位置来打印确切的值,大多数类似unix的操作系统会打印确切的值,或者正确舍入到所请求的位数的值。 MSVCRT舍入到固定数量的位置,并用零填充其余的位置。这两种行为都是一致的,但后者实际上是丑陋和低质量的。