问题提出:
int main()
{
double i = 20.0;
double j = i / 7.0;
if (j * 7.0 == i)
printf(“equal\n”);
else
printf(“not equal\n”);
return 0;
}
上述代码在vs编译器下的运行结果为equal,在Linux环境下运行结果为not equal。造成这种结果的原因是什么?
知识储配:浮点数在内存中的存储方式:浮点数是怎么存储的
分析原因:
因为浮点数在内存中的存储方式使得,有些浮点数在内存中无法精确的存储,这样就必然有精度的丢失。一旦丢失就可能计算不够准确。无法使用 == 直接判断两个浮点数相等。
问题解决:
设置一个能接受的精度,保证误差在精度范围内就可以了
#define EXP 0.0000000001
float f = 0.0000001;
if(((f-21.0) > -EXP)&&((f-21.0) < EXP)) //判断f==21
{
//就意味着f是无限接近0的数字,就约等于0
}
本文探讨了在不同编译器环境下,浮点数运算可能导致的精度问题,并提供了一种解决方案来判断两个浮点数是否相等。
1663

被折叠的 条评论
为什么被折叠?



