zoukankan      html  css  js  c++  java
  • 如何保证javascript算数计算结果的精度

    前言:

    我们先看如下这个js的代数计算结果,什么? 明显不是我们想要的结果3.52!!

    备注:其实这个小数计算精度问题,在弱类型语言python等语言中同样存在。

    问题原因之所在:

    JavaScript 语言的底层根本没有整数,所有数字都是小数(64位浮点数)。容易造成混淆的是,某些运算只有整数才能完成,此时 JavaScript 会自动把64位浮点数,转成32位整数,然后再进行运算!!

    由于浮点数不是精确的值,所以涉及小数的比较和运算要特别小心。

    解决方法:

    解决的方案应该有很多种,下面介绍,我这边总结的一种方法。

    parseFloat((2.3+1.22).toFixed(10))

     思路分为如下两步,

    1、将计算结果保留10位小数,

    2、然后再用parseFloat这个全局函数来解析一下,即可得到我们想要的结果。

    小结:

    parseFloat 除了可以将字符串解析为浮点数,还有一个功能就是把类似2.3002000这种小数的尾部的0都去掉。

  • 相关阅读:
    每日日报7月15日
    每日日报7月14日
    ecplise下 java问题处理
    Visual Studio Code for .Net Framework
    Go语言操作MySQL数据库
    Go语言Gin-4中间件
    Go语言Gin-2.数据传输
    Go语言Gin-1.路由
    13.Go语言-并发编程
    12.Go语言-网络编程
  • 原文地址:https://www.cnblogs.com/teamemory/p/11719607.html
Copyright © 2011-2022 走看看