JS加减乘除运算精度缺失问题

计算机在计算时会把数字转化为二进制来计算,此时只能模仿十进制进行四舍五入,但是二进制只有 0 和 1 两个,于是变为 0 舍 1 入。这是浮点数运算时出现误差,丢失精度的原因。

为了解决这些问题,我们可以把浮点数乘以一个数,时期变为整数再进行运算,之后再除以这个数,恢复原来的大小来解决浮点数计算精度缺失的问题,下面是我总结的一些代码,可以直接拿来当模板用。

 

 

// 加法
    numAdd (num1, num2) {
      let baseNum, baseNum1, baseNum2
      try {
        baseNum1 = num1.toString().split('.')[1].length
      } catch (e) {
        baseNum1 = 0
      }
      try {
        baseNum2 = num2.toString().split('.')[1].length
      } catch (e) {
        baseNum2 = 0
      }
      baseNum = Math.pow(10, Math.max(baseNum1, baseNum2))
      return Math.round(num1 * baseNum + num2 * baseNum) / baseNum
    },
    // 减法
    accSub (num1, num2) {
      let r1, r2, m, n
      try {
        r1 = num1.toString().split('.')[1].length
      } catch (e) {
        r1 = 0
      }
      try {
        r2 = num2.toString().split('.')[1].length
      } catch (e) {
        r2 = 0
      }
      m = Math.pow(10, Math.max(r1, r2))
      n = (r1 >= r2) ? r1 : r2
      return (Math.round(num1 * m - num2 * m) / m).toFixed(n)
    },

    // 乘法
    accMul (num1, num2) {
      let m, s1, s2
      m = 0
      s1 = num1.toString()
      s2 = num2.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)
    },

    // 除法
    accDiv (num1, num2) {
      let t1, t2, r1, r2
      try {
        t1 = num1.toString().split('.')[1].length
      } catch (e) {
        t1 = 0
      }
      try {
        t2 = num2.toString().split('.')[1].length
      } catch (e) {
        t2 = 0
      }
      r1 = Number(num1.toString().replace('.', ''))
      r2 = Number(num2.toString().replace('.', ''))
      return (r1 / r2) * Math.pow(10, t2 - t1)
    }

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值