【发布时间】:2016-05-11 03:21:01
【问题描述】:
作者在学习在线视频中的C要领时,分享了下面的代码,以找出float、double和long double之间的区别。 我在运行在 64 位 Windows 10 笔记本电脑上的 Eclispse 中运行了这个程序。
#include <stdio.h>
#include <stdlib.h>
int main(void) {
puts("Floating point type usage in C:");
// Floating point types
float floatNumber;
double doubleNumber;
long double longDoubleNumber;
// Size of floating point types
//lu - Stands for "unsigned decimal integer" and "long"
printf("Storage size for unsigned float : %lu bytes \n", sizeof(float));
printf("Storage size for double : %lu bytes \n", sizeof(double));
printf("Storage size for long double : %lu bytes \n", sizeof(long double));
floatNumber = 2.0/3.0;
doubleNumber = 2.0/3.0;
longDoubleNumber = 2.0/3.0;
puts("\nCompare precision at 4 decimal points:");
printf("floatNumber = %1.4f\n", floatNumber);
printf("doubleNumber = %1.4lf\n", doubleNumber);
printf("longDoubleNumber = %1.4Lf\n", longDoubleNumber);
puts("\nCompare precision at 10 decimal points:");
printf("floatNumber = %1.10f\n", floatNumber);
printf("doubleNumber = %1.10lf\n", doubleNumber);
printf("longDoubleNumber = %1.10Lf\n", longDoubleNumber);
puts("\nCompare precision at 30 decimal points:");
printf("floatNumber = %1.30f\n", floatNumber);
printf("doubleNumber = %1.30lf\n", doubleNumber);
printf("longDoubleNumber = %1.30g\n", longDoubleNumber);
return 0;
}
不知何故,我没有得到预期的输出。 我已经添加了我在 Eclispse 控制台中得到的输出。 谁能帮我找出问题所在
Floating point type usage in C:
Storage size for unsigned float : 4 bytes
Storage size for double : 8 bytes
Storage size for long double : 16 bytes
Compare precision at 4 decimal points:
floatNumber = 0.6667
doubleNumber = 0.6667
longDoubleNumber = 0.0000 //Expected value = 0.6667
Compare precision at 10 decimal points:
floatNumber = 0.6666666865
doubleNumber = 0.6666666667
longDoubleNumber = 0.0000000000 //Expected value = 0.6666666667
Compare precision at 30 decimal points:
floatNumber = 0.666666686534881590000000000000
doubleNumber = 0.666666666666666630000000000000
longDoubleNumber = 3.1728895775924853e-317 //This is not the expected value
【问题讨论】:
-
您使用的是什么编译器和运行时/libc?
-
试试
longDoubleNumber = (long double)2.0/3.0; -
@sjsam,原始代码中缺少强制转换可能是故意的。无论如何,它并没有解释所呈现的输出。
-
30 位变体应使用
%1.30Lg或%1.30Lf,而不是%1.30f。但我怀疑该修复程序能否获得您期望的输出,因为其他long double输出也不正确。在我看来,您的编译器或 C 库似乎有问题/不符合标准。 -
@JohnBollinger:或者它可能是编译器/库不匹配。例如。在 Windows 上,msvcrt 假定 long double == double。
标签: c double format-specifiers long-double length-modifiers