js采用IEEE-745浮点数表示法,这是一种二进制表示法。但是有许多小数用二进制来表示是无限循环的,因此js中64位的存储并不能很精确地表示一些小数。就会导致如下情况:
0.1+0.2 === 0.3; //false
那么如何来判断上述式子为true呢?
最常见的方法是设置一个误差范围值,通常称为机器精度。对js的数字来说,这个值通常是2^-52.
从ES6开始,这个值被定义在Number.EPSILON中,我们可以直接拿来用,也可以为ES6之前的版本写polyfill:
if(!Number.EPSILON){
Number.EPSILON = Math.pow(2,-52)
}
可以用Number.EPSILON来比较两个数字是否相等(在指定的误差范围内):
function nearlyEqual(n1,n2){
return Math.abs(n1-n2)<Number.EPSILON;
}
var a = 0.1+0.2;
var b = 0.3;
nearlyEqual(a,b); //true