JavaScript数字基于IEEE 754双精度浮点,最大安全整数为2^53-1,超范围或小数运算如0.1+0.2≠0.3会导致精度问题。解决大数用BigInt类型,通过加n或BigInt()创建,支持大整数精确运算但不兼容number和Math方法;小数精度问题可通过放大法转整数计算、toFixed()格式化显示或使用误差范围判断近似相等来缓解。

JavaScript 中的数字类型基于 IEEE 754 标准的双精度浮点数,这意味着它能表示的最大安全整数是 Number.MAX_SAFE_INTEGER(即 2^53 - 1),超过这个范围的数值会出现精度丢失。同时,在进行小数运算时,如 0.1 + 0.2 !== 0.3 的问题也广为人知。要解决大数运算和精度控制问题,需要采取特定策略。
大整数运算:使用 BigInt
对于超出安全整数范围的大整数,JavaScript 提供了 BigInt 类型,可以准确表示任意大的整数。
说明:- 通过在整数后加
n或调用BigInt()构造函数创建 BigInt 值。 - BigInt 不兼容普通 number 类型,不能混合运算或用于 Math 方法中。
- 支持常见的算术操作(+、-、*、**、%),但不支持除法的精确小数结果(/ 操作会自动丢弃小数部分)。
示例:
const a = 123456789012345678901234567890n;
const b = BigInt("987654321098765432109876543210");
const sum = a + b;
console.log(sum); // 正确输出大整数结果
小数精度问题:避免浮点误差
浮点数计算误差源于二进制无法精确表示某些十进制小数(如 0.1)。处理方式包括转换为整数运算或使用工具库。
立即学习“Java免费学习笔记(深入)”;
可编程序控制器,英文称Programmable Controller,简称PC。但由于PC容易和个人计算机(Personal Computer)混淆,故人们仍习惯地用PLC作为可编程序控制器的缩写。它是一个以微处理器为核心的数字运算操作的电子系统装置,专为在工业现场应用而设计,它采用可编程序的存储器,用以在其内部存储执行逻辑运算、顺序控制、定时/计数和算术运算等操作指令,并通过数字式或模拟式的输入、输出接口,控制各种类型的机械或生产过程。本平台提供PLC编程入门基础知识下载,需要的朋友们下载看看吧!
-
放大法:将小数乘以 10^n 转为整数运算后再还原。例如:
(0.1 * 100 + 0.2 * 100) / 100 === 0.3 -
toFixed() 配合 parseFloat:用于格式化显示,但注意 toFixed 返回字符串,且可能四舍五入。
parseFloat((0.1 + 0.2).toFixed(1)) === 0.3 -
避免直接比较浮点数相等性:使用误差范围(epsilon)判断是否“近似相等”:
Math.abs(a - b)
高精度计算:引入第三方库
当项目涉及复杂的小数运算(如金融计算),推荐使用专门的高精度数学库。
常用库:- decimal.js:功能全面,支持任意精度的十进制运算,API 友好。
- big.js:轻量级,适合简单场景,专注于加减乘除。
- mathjs:提供扩展数学功能,支持 BigNumber 模式。
示例(decimal.js):
const Decimal = require('decimal.js');
let a = new Decimal(0.1);
let b = new Decimal(0.2);
let result = a.plus(b);
console.log(result.equals(0.3)); // true
基本上就这些。根据实际需求选择合适的方法:BigInt 处理超大整数,放大法应对简单小数误差,复杂场景用 decimal.js 等库保障精度。关键是意识到 JavaScript 数字类型的局限,并主动规避风险。









