吉大建设工程学院官方网站/免费发布信息不收费的网站

吉大建设工程学院官方网站,免费发布信息不收费的网站,如何上传图片到网站,做网站 就上凡科网JavaScript 金额运算精度丢失问题及解决方案 1. 前言2. 为什么 JavaScript 计算金额会精度丢失?2.1 JavaScript 使用 IEEE 754 双精度浮点数2.2 浮点运算错误示例**错误示例 1:0.1 0.2 ≠ 0.3****错误示例 2:浮点乘法精度问题** 3. 解决方案…

JavaScript 金额运算精度丢失问题及解决方案

    • 1. 前言
    • 2. 为什么 JavaScript 计算金额会精度丢失?
      • 2.1 JavaScript 使用 IEEE 754 双精度浮点数
      • 2.2 浮点运算错误示例
        • **错误示例 1:0.1 + 0.2 ≠ 0.3**
        • **错误示例 2:浮点乘法精度问题**
    • 3. 解决方案
      • **方案 1:使用整数运算(推荐)**
      • **方案 2:使用 `toFixed()`(简单但不推荐)**
      • **方案 3:使用 `Number.EPSILON` 进行误差修正**
      • **方案 4:使用 BigDecimal 类库(最佳方案)**
      • **方案 5:使用 ES11 `BigInt`(适用于整数金额计算)**
    • 4. 结论
    • 5. 总结

1. 前言

在 JavaScript 中,浮点数运算可能会产生精度丢失的问题,尤其在处理 金额计算 时,这可能会导致严重的业务逻辑错误。例如:

console.log(0.1 + 0.2); // 0.30000000000000004
console.log(0.07 * 100); // 7.000000000000001
console.log(0.1 + 0.7 === 0.8); // false

这些问题主要是由于 JavaScript 使用 IEEE 754 双精度浮点数(64 位)来表示数字,某些小数无法用二进制精确表示,从而导致精度丢失。

本篇文章将深入剖析 JavaScript 金额计算精度丢失的原因,并提供多种 解决方案 来避免这些问题。


2. 为什么 JavaScript 计算金额会精度丢失?

2.1 JavaScript 使用 IEEE 754 双精度浮点数

JavaScript 所有的 Number 类型 都遵循 IEEE 754 双精度浮点数(64 位)标准,它的存储方式如下:

符号位指数位尾数位(小数部分)
1 位11 位52 位

某些十进制小数无法用二进制精确表示,类似于 1/3 在十进制中是无限循环小数 0.3333...,而 0.1二进制 下也会变成 无限循环小数

0.1(十进制) = 0.000110011001100110011...(二进制 无限循环)

由于存储空间限制,JavaScript 只能截取前 52 位,导致数值被四舍五入,最终引发计算误差。


2.2 浮点运算错误示例

错误示例 1:0.1 + 0.2 ≠ 0.3
console.log(0.1 + 0.2); // 0.30000000000000004

解析

  1. 0.1 的二进制近似值:0.00011001100110011...
  2. 0.2 的二进制近似值:0.0011001100110011...
  3. 计算后,得到的二进制不是 精确的 0.3,而是 0.30000000000000004

错误示例 2:浮点乘法精度问题
console.log(0.07 * 100); // 7.000000000000001

0.07 转换成二进制后是 0.000100011110101110000101...,乘以 100 后的结果并不完全等于 7


3. 解决方案

方案 1:使用整数运算(推荐)

核心思想
避免小数计算,将小数转换为整数计算,计算完成后再转回小数。

function add(a, b) {return (a * 100 + b * 100) / 100;
}console.log(add(0.1, 0.2)); // 0.3
console.log(add(0.07, 0.02)); // 0.09

适用场景

  • 适用于 加法、减法、乘法、除法 计算。
  • 适用于 金额计算,例如:分(整数)代替元(小数)。

方案 2:使用 toFixed()(简单但不推荐)

console.log((0.1 + 0.2).toFixed(2)); // "0.30"
console.log((0.07 * 100).toFixed(2)); // "7.00"

缺点

  • toFixed() 返回的是 字符串,如果要继续计算,还需转换回 Number 类型:
    let result = Number((0.1 + 0.2).toFixed(2)); // 0.3
    
  • 不能完全解决浮点运算的问题,只适用于 结果展示

方案 3:使用 Number.EPSILON 进行误差修正

原理
Number.EPSILON 是 JavaScript 最小的精度差值(约 2.22e-16),可用于修正浮点计算误差:

function add(a, b) {return Math.round((a + b + Number.EPSILON) * 100) / 100;
}console.log(add(0.1, 0.2)); // 0.3
console.log(add(0.07, 0.02)); // 0.09

适用场景

  • 用于 浮点数精度修正,避免直接使用 toFixed()

方案 4:使用 BigDecimal 类库(最佳方案)

JavaScript 原生 Number 无法解决所有精度问题,因此可以使用 BigDecimal 第三方库 来进行精准计算,例如 decimal.js

安装:

npm install decimal.js

使用:

const Decimal = require('decimal.js');console.log(new Decimal(0.1).plus(0.2).toNumber()); // 0.3
console.log(new Decimal(0.07).times(100).toNumber()); // 7

优点

  • 可以处理 任意精度 运算,特别适用于 金融计算

方案 5:使用 ES11 BigInt(适用于整数金额计算)

BigInt 可用于 大数计算,但 不支持小数

const a = BigInt(100); // 1.00 元
const b = BigInt(200); // 2.00 元console.log((a + b) / BigInt(100)); // 3n (表示 3 元)

适用场景

  • 仅适用于 整数计算(如分单位),不适用于 小数计算

4. 结论

方案适用场景优点缺点
整数运算(推荐)金额计算高效、适用范围广需要手动转换
toFixed()仅限展示简单易用结果为字符串,无法继续计算
Number.EPSILON浮点修正适用于加减运算不适用于复杂运算
decimal.js(最佳)任何精度计算高精度,API 强大需引入库
BigInt整数计算适用于大数运算不支持小数

5. 总结

JavaScript 的浮点运算容易导致金额计算误差,我们可以通过 整数运算、Number.EPSILON、BigDecimal 库等方式 来解决。

如果你正在开发电商、金融、结算系统推荐使用 decimal.js 或整数运算,以保证计算精度。

你还遇到过 JavaScript 金额计算的问题吗?欢迎留言讨论!🚀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/72820.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

国内首台太空采矿机器人亮相,宇宙资源开发迈入新阶段

随着地球资源的日益枯竭,人类将目光投向了浩瀚的宇宙。太空采矿作为一项前沿科技,正逐步从科幻走向现实。近日,中国矿业大学成功研制出国内首台太空采矿机器人,标志着我国在太空资源开发领域迈出了重要一步。 太空采矿并非新鲜概念…

Kubeasz工具快速部署K8Sv1.27版本集群(二进制方式)

文章目录 一、基本信息二、服务器初始化操作三、使用Kubeasz部署K8S集群四、验证集群 一、基本信息 1、部署需要满足前提条件: 注意1:确保各节点时区设置一致、时间同步;注意2:确保在干净的系统上开始安装;注意3&…

Java 文件和IO流基础(生动形象版)

系列文章目录 Java文件和IO流基础部分 文件VSIO流 文章目录 系列文章目录前言一、文件的定义和理解: 1.专业定义: 2.文件系统和路径: 二、IO流的定义和分类 1.定义:2.流的分类:修饰器模式的核心作用:基础结…

Linux驱动学习笔记(四)

高级字符设备进阶 1.一个完整的IO过程包含以下几个步骤:1应用程序向操作系统发起IO调用请求(系统调用);2操作系统准备数据,把IO设备的数据加载到内核缓冲区;3操作系统拷贝数据,把内核缓冲区的数据从内核空间拷贝到应用…

2025年,电脑还需要分区吗?

随着2025年的到来,电脑存储空间已经不像以前那么金贵,固态硬盘(SSD)容量更大、速度更快,云存储也成了日常标配。许多人开始质疑:电脑还需要像以前那样分区吗? 一、分区到底是什么意思&#xff…

Springboot项目集成maven-assembly-plugin进行打包

通常我们将应用部署到服务器的某个目录下,一般情况下我们会提供像target(存放应用jar包),bin(项目启动/停止脚本),config(项目配置文件),logs(项目…

鸿蒙NEXT项目实战-百得知识库01

代码仓地址,大家记得点个star IbestKnowTeach: 百得知识库基于鸿蒙NEXT稳定版实现的一款企业级开发项目案例。 本案例涉及到多个鸿蒙相关技术知识点: 1、布局 2、配置文件 3、组件的封装和使用 4、路由的使用 5、请求响应拦截器的封装 6、位置服务 7、三…

【DeepSeek应用】本地部署deepseek模型后,如何在vscode中调用该模型进行代码撰写,检视和优化?

若已成功在本地部署了 DeepSeek 模型(例如通过 vscode-llm、ollama 或私有 API 服务),在 VS Code 中调用本地模型进行代码撰写、检视和优化的完整流程如下: 1. 准备工作:确认本地模型服务状态 模型服务类型: 若使用 HTTP API 服务(如 FastAPI/Flask 封装),假设服务地址…

jenkins 配置邮件问题整理

版本:Jenkins 2.492.1 插件: A.jenkins自带的, B.安装功能强大的插件 配置流程: 1. jenkins->系统配置->Jenkins Location 此处的”系统管理员邮件地址“,是配置之后发件人的email。 2.配置系统自带的邮件A…

Android Coil3阶梯preload批量Bitmap拼接扁平宽图,Kotlin

Android Coil3阶梯preload批量Bitmap拼接扁平宽图&#xff0c;Kotlin <uses-permission android:name"android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name"android.permission.READ_EXTERNAL_STORAGE" /><uses-p…

C++基础 [八] - list的使用与模拟实现

目录 list的介绍 List的迭代器失效问题 List中sort的效率测试 list 容器的模拟实现思想 模块分析 作用分析 list_node类设计 list 的迭代器类设计 迭代器类--存在的意义 迭代器类--模拟实现 模板参数 和 成员变量 构造函数 * 运算符的重载 运算符的重载 -- 运…

【系统架构设计师】操作系统 - 特殊操作系统 ③ ( 微内核操作系统 | 单体内核 操作系统 | 内核态 | 用户态 | 单体内核 与 微内核 对比 )

文章目录 一、微内核操作系统1、单体内核 操作系统2、微内核操作系统 引入3、微内核操作系统 概念4、微内核操作系统 案例 二、单体内核 与 微内核 对比1、功能对比2、单体内核 优缺点3、微内核 优缺点 一、微内核操作系统 1、单体内核 操作系统 单体内核 操作系统 工作状态 : …

系统思考:恶性循环

去年&#xff0c;我给一家知名人力资源公司交付了两个项目——一个在6月&#xff0c;另一个在8月&#xff0c;至今半年多了依然没有收到课酬。催促多次&#xff0c;得到的答复却各式各样&#xff1a;销售说老板卡了额度&#xff0c;老板说具体情况还需了解。每一次的推诿&#…

基于springboot的房屋租赁系统(008)

摘 要 社会的发展和科学技术的进步&#xff0c;互联网技术越来越受欢迎。网络计算机的生活方式逐渐受到广大人民群众的喜爱&#xff0c;也逐渐进入了每个用户的使用。互联网具有便利性&#xff0c;速度快&#xff0c;效率高&#xff0c;成本低等优点。 因此&#xff0c;构建符…

视频翻译器免费哪个好?轻松玩转视频直播翻译

你是不是觉得看外语视频很麻烦&#xff1f;每次遇到喜欢的外语电影、电视剧或动漫&#xff0c;总是要等字幕组的翻译&#xff0c;或者因为语言不通而错过精彩的情节。 这个时候&#xff0c;掌握多语种直播翻译方案就显得尤为重要&#xff0c;有了实时字幕&#xff0c;看外语视…

在cherry studio中使用MCP——本地文件管理FileSystem

cherry studio是一款开源的AI助手工具&#xff0c;可以便捷地利用API访问各种LLM&#xff0c;有关cherry studio的使用这里不再多说&#xff0c;可以参考这篇文章https://blog.csdn.net/m0_65494437/article/details/145478823 官网&#xff1a;https://cherry-ai.com/ MCP是什…

c++类和对象(下篇)下

下面就来补充一下c雷和对象最后一点内容. 首先先补充一下上一篇博客上c类和对象(下篇)上-CSDN博客最后学习的静态成员变量的小练习求123...n_牛客题霸_牛客网 (nowcoder.com)下面就是题解.灵活的运用了静态成员变量不销毁的特点,建立数组利用构造函数来完成n次相加. class A{ …

《TCP/IP网络编程》学习笔记 | Chapter 19:Windows 平台下线程的使用

《TCP/IP网络编程》学习笔记 | Chapter 19&#xff1a;Windows 平台下线程的使用 《TCP/IP网络编程》学习笔记 | Chapter 19&#xff1a;Windows 平台下线程的使用内核对象内核对象的定义内核对象归操作系统所有 基于 Windows 的线程创建进程与线程的关系Windows 中线程的创建方…

docker需要sudo才能使用

一种方法是添加当前用户到docker组里去&#xff0c;当时添加的时候貌似是没问题的&#xff0c;但是现在又不可以了 产生的报错 ❯ docker images Cannot connect to the Docker daemon at unix:///home/ying/.docker/desktop/docker.sock. Is the docker daemon running?解决…

学习记录 6 pointnet复现

一、复现代码 然后去找相关的2d的声呐图像分类的算法 融合可以搞的&#xff0c;虽然有文献但是不多&#xff0c;感觉也是可以的 """ Author: Benny Date: Nov 2019 """import os import sys import torch import numpy as npimport datetime …