请问老师js里遇到小数,或者除不尽的地方会出现bug,貌似每次出现的值都不一样请问咋解决?
来源:1-13 js运算符
轩辕小齐V
2018-11-22 20:50:30
var n = 1/3; console.log(n);
据说js对浮点值不是很支持,经常会出现问题,小数点之后会出现很多位而且每次计算都不一样,请问老师怎么解决?比如价格等场景就经常会遇到,怎么能保证经过计算后的值精准且稳定呢?
比如说,在小程序内,需要前端先进性计算,不是所有都是从后台拿过来的。
我不知道回答相同问题的是不是老师,不过那个回答真的有点砸场子,我没有搜到,7月老师讲的方法给忘了,但是很简单,麻烦老师再指导下!谢谢!
1回答
你好,关于js浮点数计算精度不准确问题的解决办法
在计算商品价格的时候再次遇到js浮点数计算出现误差的问题,具体解决方法参考如下:
浮点数误差产生的原因:
先看一个实例:
0.1 + 0.2 =? 0.1 + 0.2 = 0.3?
我们先来看一段 JS。
console.log( 0.1+ 0.2);
输出为 0.30000000000000004。
其实对于浮点数的四则运算,几乎所有的编程语言都会有类似精度误差的问题,只不过在 C++/C#/Java 这些语言中已经封装好了方法来避免精度的问题,而 JavaScript 是一门弱类型的语言,从设计思想上就没有对浮点数有个严格的数据类型,所以精度误差的问题就显得格外突出。下面就分析下为什么会有这个精度误差,以及怎样修复这个误差。
首先,我们要站在计算机的角度思考 0.1 + 0.2 这个看似小儿科的问题。我们知道,能被计算机读懂的是二进制,而不是十进制,所以我们先把 0.1 和 0.2 转换成二进制看看:
0.1 => 0.0001 1001 1001 1001…(无限循环) 0.2 => 0.0011 0011 0011 0011…(无限循环)
上面我们发现0.1和0.2转化为二进制之后,变成了一个无限循环的数字,这在现实生活中,无限循环我们可以理解,但计算机是不允许无限循环的,对于无限循环的小数,计算机会进行舍入处理。进行双精度浮点数的小数部分最多支持 52 位,所以两者相加之后得到这么一串 0.0100110011001100110011001100110011001100110011001100 因浮点数小数位的限制而截断的二进制数字,这时候,我们再把它转换为十进制,就成了 0.30000000000000004。
知道了浮点数产生的原因了,那么怎么处理这个问题呢?
方法一:指定要保留的小数位数(0.1+0.2).toFixed(1) = 0.3;这个方法toFixed是进行四舍五入的也不是很精准,对于计算金额这种严谨的问题,不推荐使用,而且不通浏览器对toFixed的计算结果也存在差异。
方法二:把需要计算的数字升级(乘以10的n次幂)成计算机能够精确识别的整数,等计算完毕再降级(除以10的n次幂),这是大部分编程语言处理精度差异的通用方法。
eg:(0.1*10 + 0.2*10) / 10 == 0.3 // true
如果解决您的问题请采纳,祝学习愉快!
相似问题