zoukankan      html  css  js  c++  java
  • 为什么 0.1 + 0.2 结果为 0.30000000000000004

    > 0.1 + 0.2 == 0.3
    false
    
    > 0.1 + 0.2
    0.30000000000000004
    这只是JavaScript遵循IEEE 754标准所产生的必然结果。IEEE 754标准中的浮点数并不能精确地表达小数(比如说0.1),
     
    • 你需要足够的内存来保留5个数字
    • 你需要使用一个取值范围来确保精度。

    JavaScript中的小数采用的是双精度(64位)表示的,由三部分组成: 符 + 阶码 + 尾数,在十进制中的 1/10,在十进制中可以简单写为 0.1 ,但在二进制中,他得写成:0.0001100110011001100110011001100110011001100110011001…..(后面全是 1001 循环)。因为浮点数只有52位有效数字,从第53位开始,就舍入了。这样就造成了“浮点数精度损失”问题。

    在写代码时小心踩坑

    你在写代码的过程中,遇到小数都要小心,比如下面的代码会造成死循环

    var i = 0.1
    while(i!=1){
        console.log(i)
        i += 0.1
    }

    解决办法:

    使用JavaScript内置的函数toPrecision或toFixed来保留一定的精度:

    (0.1 + 0.2).toPrecision(10) == 0.3  //true
    
    
    (0.1 + 0.2).toFixed(10) == 0.3   //true
  • 相关阅读:
    二叉树的下一个节点
    二叉树的对称
    CString,string和char*
    二叉平衡树
    二叉树的深度
    必应首页图片下载
    Git报错:fatal: remote origin already exists.
    sublime text3 自定义代码片段
    atom自定义C++代码片段
    vscode 自定义代码片段(snippets)
  • 原文地址:https://www.cnblogs.com/feilu2016/p/6944722.html
Copyright © 2011-2022 走看看