javascript中浮点数相加的一些细节

问题来源:有时候我们在对小数进行相加时会出现小数部分的无限循环,得到相加的结果并不准确。这是因为JavaScript 中的 number 浮点型是一种二进制表示法,可以精确地表示分数,但是,二进制浮点数表示法并不能精确的表示类似0.1这样 的简单的数字,会有舍入误差;

比如:

         console.log(0.1+0.2);

         输出结果为:0.30000000000000004

        console.log(0.31+0.5111);

         输出结果为: 0.8210999999999999

解决办法:

        function add(num1,num2)

         {
           let a1,a2,m;
           a1 = (''+num1).split('.')[1].length;
           a2 = (''+num2).split('.')[1].length;
           m = Math.pow(10,Math.max(a1,a2));
           return(num1*m + num2*m)/m;
         }
           console.log(add(0.1,0.2));
           console.log(add(0.31,0.5111));

        输出结果: 0.3
        输出结果: 0.8211




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值