请教一个JavaScript浮点数的问题

我尝试将小数乘以倍数来修复浮点数的bug:

Math.plus = (...numbers) => {
    return numbers.reduce((acc,cur) => (acc * 1000 + cur * 1000) / 1000);    
};

但发现有的数能计算正确,有的还是会出现浮点数bug:

console.log(Math.plus(16.141,0.016));    //16.156999999999996

console.log(Math.plus(16.201,0.016));    //16.217

console.log ( (16141 + 16) / 1000 );    //16.157

请问如何解决这个问题呢?

阅读 2.2k
2 个回答
Math.plus = (...numbers) => {
    return numbers.reduce((acc,cur) => (acc + cur).toFixed(3));    
};
console.log(Math.plus(16.141,0.016));    //16.157
console.log(Math.plus(16.201,0.016));    //16.217
console.log ( (16141 + 16) / 1000 );    //16.157

日经问题,请自行搜索:舍入误差

解决方案无非是两个:

  1. 对精度要求不高的时候,可以直接采用定点运算,即对确定的小数位数直接进行四舍五入。

  2. 对精度要求很高时,采用高精度(大数)运算,这一点网上资料很多,请自行查阅。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题