浮点数的最高精度是17位小数,但是在实际计算时会产生莫名其妙的问题,如0.1+0.2的结果不是0.3,而是0.30000000000000004,这个舍入误差会导致无法测试特定的浮点数值。
例如
var a=0.1,b=0.2;
if(a+b==0.3){
//这里的语句永远不会被执行到,因为a+b的结果是:0.30000000000000004
}
关于浮点数值计算会产生舍入误差的问题,需要说明,这是使用基于IEEE745数值的浮点计算的通病,并不是只有JavaScript如此,其他使用相同数值格式的语言也存在这个问题。
在Java中也会出现类似的问题,如下面的java代码其结果也并不是0.3:
double a = 0.1f;
double b = 0.2f;
double c = a+b;
System.out.println("c = " + c);