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 已无法被精确表示
每个应用程序都要使用数据,Android应用程序也不例外,Android使用开源的、与操作系统无关的SQL数据库--SQLite,本文介绍的就是如何为你的Android应用程序创建和操作SQLite数据库。 数据库支持每个应用程序无论大小的生命线,除非你的应用程序只处理简单的数据,那么就需要一个数据库系统存储你的结构化数据,Android使用SQLite数据库,它是一个开源的、支持多操作系统的SQL数据库,在许多领域广泛使用,如Mozilla FireFox就是使用SQLite来存储配置数据的,iPhon
BigInt 用任意精度整数(arbitrary-precision integer)实现,能准确表达任意大(或小)的整数,只要内存允许。
如何创建和使用 BigInt
- 字面量写法:在整数末尾加
n,如123n、0n、-456n - 构造函数写法:
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 位整数)









