为什么明明相等的等式不相等?


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则代表这两个浮点数相等