欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

浮点型数据和0进行比较的探究

程序员文章站 2022-03-30 16:39:48
...

问题提出:

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
}