• 技术文章 >web前端 >js教程

    探讨javascript浮点值运算是舍入误差的原因

    巴扎黑巴扎黑2017-07-22 16:54:28原创688

    问题

    在javascript中整数和浮点数都属于Number数据类型(简单数据类型中的一种),我们经常会发现在打印1.0这样的浮点数的结果是1而非1.0,这是由于保存浮点数的内存空间是保存整数值的两倍,所以ECMAScript会不失时机地将浮点数转换为整数。
    上面这种情况虽然让强迫症患者有点不舒服,但是好歹也不是什么大错,接下来这种情况就很吓人了。例如我们在计算0.10.2时,它的输出结果不是0.3,而是0.3000000000000004。what the fuck?!第一次遇到这种情况的童鞋有没有感觉到世界观受到了挑战?

    产生原因

    于是赶快翻书来拯救自己的灵魂以及肉体,发现书中赫然写着:ECMAScrip是基于IEEE754数值浮点计算,这种数值计算方法会将数值保存为二进制然后进行计算,由于浮点数用二进制表达时是无穷的,所以在进行算术计算时会产生舍入误差,由于舍入误差的存在,浮点数计算的精确度远远不如整数计算,最后记住了永远不要测试某个特定浮点数的数值

    解决方案

    所谓对症下药,知道了问题产生的原因那么就可以找到问题的解决方案啦。既然是由于浮点数的二进制为无穷数产生的误差,这种误差在整数运算中不会存在,聪明的你是不是窥破真相了呢?没错,那就是在运算工程中将浮点数转换为整数,再将得出的结果转换为浮点数。客官,下面是新鲜上的代码~

    1 //加法  2 function FloatAdd(arg1,arg2){  
    3        var r1,r2,m; 
    4        try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0; //参数1为整数};  //参数1小数点后的位数5        try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0; //参数2为整数}; //参数2小数点后的位数6        m=Math.pow(10,Math.max(r1,r2));  //取其中较大的位数7        return (arg1*m+arg2*m)/m;        //先将arg1和arg2转换为整数进行计算,然后再转换回浮点数8   }


    以上转载 附上原网址


    toFixed() 方法应该也可以傻瓜式地处理一部分舍入误差问题。

    语法:number.toFixed(x) x:规定小数的位数,是 0 ~ 20 之间的值,包括 0 和 20,有些实现可以支持更大的数值范围。如果省略了该参数,将用 0 代替。


    END


    以上就是探讨javascript浮点值运算是舍入误差的原因的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:javascript js 误差
    上一篇:对JavaScript ES6的常用总结之数组、函数、对象的扩展 下一篇:JavaScript ES6中let与const比较

    相关文章推荐

    • 聊聊Node.js + worker_threads如何实现多线程?(详解)• JS实现情人节爱心满屏飘落的唯美特效(附完整代码)• 总结分享一些使用jQuery实现的DOM操作(收藏)• 完全掌握JavaScript预编译过程• 什么是Express中间件?Node中要怎么使用?

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网