int main(int argc, const char * argv[]) {
int n = 0;
double a = 43*1.1
double b = 43 + 43*0.1;
if(a==b)
n = 1;
if(a>b)
n = 2;
printf("%f\n",a-b);
printf("%f %f\n",a,b);
printf("%d\n",n);
return 0;
}
上述代码,在a,b相等时,会输出n=1;在a>b时,会输出n=2;在a<b时,会输出n=0.
任取一个大于等于43的正整数,发现明显相等的等式竟然不相等,而奇怪的是,当该数小于43时,这样神奇的现象却又消失了,各位网友们,请问这是为什么呢?
浮点数判断不能用==来判断是否相等,因为浮点数存在精度问题,你看似是47.3,实际可能是47.30000000001。
浮点数比较要用 a-b的绝对值 < 0.001 来判断这两个数是否相等,0.001这里代表精度,只是打个比方,
实数不要做相等比较,没有意义,一般用 abs(a-b)<1.0e-6 。
Math.abs(a - b) >= 0或者Math.abs(a - b) <= 0则代表这两个浮点数相等