如何解决JavaScript中0.1+0.2不等于0.3

Posted 少侠也在江湖

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何解决JavaScript中0.1+0.2不等于0.3相关的知识,希望对你有一定的参考价值。

  

console.log(0.1+0.2===0.3)//  true  or  false??

 

  在正常的数学逻辑思维中,0.1+0.2=0.3这个逻辑是正确的,但是在javascript中0.1+0.2!==0.3,这是为什么呢?这个问题也会偶尔被用来当做面试题来考查面试者对

JavaScript的数值的理解程度。

  在JavaScript中的二进制的浮点数0.1和0.2并不是十分精确,在他们相加的结果并非正好等于0.3,而是一个比较接近的数字 0.30000000000000004 ,所以条件判断结果为 false。

那么应该怎样来解决0.1+0.2等于0.3呢? 最好的方法是设置一个误差范围值,通常称为”机器精度“,而对于Javascript来说,这个值通常是2^-52,而在ES6中,已经为我们提供了这样一个

属性:Number.EPSILON,而这个值正等于2^-52。这个值非常非常小,在底层计算机已经帮我们运算好,并且无限接近0,但不等于0,。这个时候我们只要判断(0.1+0.2)-0.3小于

Number.EPSILON,在这个误差的范围内就可以判定0.1+0.2===0.3为true。

  

    function numbersequal(a,b){
        return Math.abs(a-b)<Number.EPSILON;
    }
    
    var a=0.1+0.2, b=0.3;
    console.log(numbersequal(a,b));  //true

  但是这里要考虑兼容性的问题了,在chrome中支持这个属性,但是IE并不支持(该死的IE,笔者的版本是IE10不兼容),所以我们还要解决IE的不兼容问题。

 

Number.EPSILON=(function(){     //解决兼容性问题
                return Number.EPSILON?Number.EPSILON:Math.pow(2,-52);
            })();


//上面是一个自调用函数,当JS文件刚加载到内存中,就会去判断并返回一个结果,相比if(!Number.EPSILON){
   //     Number.EPSILON=Math.pow(2,-52);
    //}这种代码更节约性能,也更美观。



function numbersequal(a,b){  
        return Math.abs(a-b)<Number.EPSILON;
    }




//接下来再判断     

        var a=0.1+0.2, b=0.3;
    console.log(numbersequal(a,b));  //这里就为true了


   

 

 

 

  

以上是关于如何解决JavaScript中0.1+0.2不等于0.3的主要内容,如果未能解决你的问题,请参考以下文章

解决JavaScript中0.1+0.2不等于0.3问题

前端面试 JavaScript— 0.1+0.2为什么不等于0.3?如何实现等于0.3?

为什么在JavaScript中0.1+0.2不等于0.3?

原来 0.1*0.2!=0.02

解决js计算0.1+0.2 !==0.3

JS小数精度问题 为什么 0.1+0.2 不等于 0.3