首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
宝塔
V2EX  ›  JavaScript

一个解决 js 浮点运算精度的代码,比市面上很多解决方案都要准确的方案^_^

  •  
  •   BarZu · 2018-02-01 11:19:50 +08:00 · 3024 次点击
    这是一个创建于 655 天前的主题,其中的信息可能已经有所发展或是发生改变。
    7 回复  |  直到 2018-02-26 18:24:03 +08:00
        1
    gomars   2018-02-01 13:58:42 +08:00
    整数
        2
    lred   2018-02-01 14:29:51 +08:00
    之前写过一个库
    https://github.com/fzred/calculatorjs
    楼主的方案不错,比我的简洁很多,介意我直接复制到我的项目吗?
        3
    sundev   2018-02-01 14:51:57 +08:00
    再加个方法,修复 toFixed 四舍五入的问题应该就齐活了!
        4
    Mutoo   2018-02-01 15:16:00 +08:00
    操作数 1:
    0.1000000000000000055511151231257827021181583404541015625
    操作数 2:
    0.200000000000000011102230246251565404236316680908203125
    相加
    结果:0.30000000000000004

    答案为什么不是 0.3000000000000000444089209850062616169452667236328125

    十进制高精度算法还是老老实实逐位运算比较靠谱
        5
    sundev   2018-02-01 15:23:48 +08:00
    @Mutoo 他的这个算法只能解决浮点数运算过程中精度丢失的问题,就是把浮点数转换为整数进行运算。但是转换后超过 16 位时,精度一样会丢失,这是 IEEE 754 标准中定义尾数部分只有 53 位决定的。
        6
    DOLLOR   2018-02-01 17:44:31 +08:00
    @Mutoo 你的答案也不对吧
    可以用
    https://github.com/MikeMcl/bignumber.js

    BigNumber('0.1000000000000000055511151231257827021181583404541015625')
    .plus('0.200000000000000011102230246251565404236316680908203125')
    .toString();

    答案应该是 0.3000000000000000166533453693773481063544750213623046875
        7
    xieranmaya   2018-02-26 18:24:03 +08:00
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4514 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 23ms · UTC 02:03 · PVG 10:03 · LAX 18:03 · JFK 21:03
    ♥ Do have faith in what you're doing.