JavaScript 需要 BigInt 是因为 Number 类型基于 IEEE 754 双精度浮点数,仅能安全表示 ≤2⁵³−1 的整数,超出则精度丢失;BigInt 提供任意精度整数运算,支持大整数精确计算,适用于金融、密码学、高精度时间戳等场景。
JavaScript 需要 BigInt 是因为标准的 Number 类型基于 IEEE 754 双精度浮点数,只能安全表示最多 253 − 1(即 9007199254740991)以内的整数。超出这个范围后,整数会开始丢失精度——这不是“算错”,而是底层二进制表示的固有限制。
BigInt 解决的核心问题:精度丢失
比如:
9007199254740991 + 1 === 9007199254740992 ✅ 正确9007199254740992 + 1 === 9007199254740992 ❌ 实际返回 true,因为 9007199254740993 已无法被精确表示
BigInt 用任意精度整数(arbitrary-precision integer)实现,能准确表达任意大(或小)的整数,只要内存允许。
如何创建和使用 BigInt
- 字面量写法:在整数末尾加
n,如123n、0n、-45
6n - 构造函数写法:
BigInt("9007199254740991999999")(注意:必须传字符串,传大数字字面量会先被转成Number导致精度丢失) - 不能与
Number混合运算:10n + 5会抛出TypeError;必须显式转换,如10n + BigInt(5) - 支持常见算术操作:
+、-、*、**、%、>>、等,但不支持/的小数结果(除法只返回商的整数部分,向下取整)
BigInt 不支持的操作和注意事项
- 不能和
Math方法一起用(如Math.pow(2n, 3n)报错),需用**运算符替代 - 不能用于
JSON.stringify()(会报错),需手动处理,例如:JSON.stringify({id: id.toString()}) - typeof 返回
"bigint",是独立的基本类型,和"number"不同 - 比较时注意类型:
10n == 10返回true(抽象相等),但10n === 10为false(严格相等要求类型一致)
典型适用场景
- 高精度金融计算(避免浮点舍入误差)
- 密码学运算(如 RSA 大素数模幂)
- 处理时间戳(如纳秒级 Unix 时间,远超
Number.MAX_SAFE_INTEGER) - 数据库中 ID 超长整数(如 Twitter Snowflake ID,常为 64 位整数)

6n






