js小数计算引起的精度误差问题

Posted 进军的王小二

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js小数计算引起的精度误差问题相关的知识,希望对你有一定的参考价值。

我记得刚开始学js的时候学到浮点有举例0.1+0.2 它的计算结果是:

0.1+0.2
0.30000000000000004

很神奇的一个计算,js是弱语言,在精度上没做处理;

我就自己定义了加减乘除:

加:

export const accAdd = (arg1, arg2) => {
  let r1, r2, m;
  try {
    r1 = arg1.toString().split(‘.‘)[1].length;
  } catch (e) {
    r1 = 0;
  }
  try {
    r2 = arg2.toString().split(‘.‘)[1].length;
  } catch (e) {
    r2 = 0;
  }
  m = Math.pow(10, Math.max(r1, r2));
  return (arg1 * m + arg2 * m) / m;
};
 
export function accSub(arg1, arg2) {
  let r1, r2, m, n;
  try {
    r1 = arg1.toString().split(‘.‘)[1].length;
  } catch (e) {
    r1 = 0;
  }
  try {
    r2 = arg2.toString().split(‘.‘)[1].length;
  } catch (e) {
    r2 = 0;
  }
  m = Math.pow(10, Math.max(r1, r2));
  //动态控制精度长度
  n = r1 >= r2 ? r1 : r2;
  return ((arg1 * m - arg2 * m) / m).toFixed(2);
}
 
export const accMul = (arg1, arg2) => {
  let m = 0,
    s1 = arg1.toString(),
    s2 = arg2.toString();
  try {
    m += s1.split(‘.‘)[1].length;
  } catch (e) {}
  try {
    m += s2.split(‘.‘)[1].length;
  } catch (e) {}
  return (
    (Number(s1.replace(‘.‘, ‘‘)) * Number(s2.replace(‘.‘, ‘‘))) /
    Math.pow(10, m)
  );
};
 
export function accDiv(arg1, arg2) {
  let t1 = 0,
    t2 = 0,
    r1,
    r2;
  try {
    t1 = arg1.toString().split(‘.‘)[1].length;
  } catch (e) {}
  try {
    t2 = arg2.toString().split(‘.‘)[1].length;
  } catch (e) {}
  r1 = Number(arg1.toString().replace(‘.‘, ‘‘));
  r2 = Number(arg2.toString().replace(‘.‘, ‘‘));
  return (r1 / r2) * Math.pow(10, t2 - t1);
}
 
这和网上搜出来的
(num1* 100 + num2* 100) / 100
去控制两位小数相加基础上去写;
 
每天都在打代码中学习
 

以上是关于js小数计算引起的精度误差问题的主要内容,如果未能解决你的问题,请参考以下文章

关于js中小数运算丢失精度的处理办法

JS小数运算失精度的问题

为何js计算带有小数的加法的时候会出现误差?

JS数字计算精度误差的解决方法

为何js计算带有小数的加法的时候会出现误差?

java,js中小数计算精度误差问题