JavaScript BigInt
JavaScript BigInt 变量用于存储太大而无法用普通 JavaScript 数字表示的大整数值。
JavaScript 整数精度
JavaScript 整数最多只能精确到 15 位:
整数精度
let x = 999999999999999; let y = 9999999999999999;
在 JavaScript 中,所有数字都以 64 位浮点格式(IEEE 754 标准)存储。
根据此标准,大整数无法被精确表示,会被四舍五入。
因此,JavaScript 只能安全地表示以下范围内的整数:
- 最大为 9007199254740991(253-1)
- 最小为 -9007199254740991(-(253-1))
超出此范围的整数值会失去精度。
如何创建 BigInt
如需创建 BigInt,可以在整数末尾添加 n
,或调用 BigInt()
函数:
例子 1
let x = 9999999999999999; let y = 9999999999999999n;
例子 2
let x = 1234567890123456789012345n; let y = BigInt(1234567890123456789012345)
BigInt:一种新的 JavaScript 数据类型
BigInt 的 JavaScript 类型是 “bigint
“:
实例
let x = BigInt(999999999999999); let type = typeof x;
BigInt 是 JavaScript 中的第二个数值数据类型(在 Number 之后)。
对于 BigInt,JavaScript 支持的数据类型总数为 8 种:
- String
- Number
- Bigint
- Boolean
- Undefined
- Null
- Symbol
- Object
BigInt 运算符
可用于 JavaScript Number 的运算符也可用于 BigInt。
BigInt 乘法实例
let x = 9007199254740995n; let y = 9007199254740995n; let z = x * y;
注意
不允许在 BigInt 和 Number 之间进行算术运算(类型转换会丢失信息)。
BigInt 无法进行无符号右移操作(>>>),因为它没有固定的宽度。
BigInt 小数
BigInt 不能有小数。
BigInt 除法实例
let x = 5n; let y = x / 2; // Error: Cannot mix BigInt and other types, use explicit conversion.
let x = 5n; let y = Number(x) / 2;
BigInt 十六进制、八进制和二进制
BigInt 也可以写成十六进制、八进制或二进制表示法:
BigInt 十六进制实例
let hex = 0x20000000000003n; let oct = 0o400000000000000003n; let bin = 0b100000000000000000000000000000000000000000000000000011n;
Precision Curiosity
舍入可能会危及程序安全:
MAX_SAFE_INTEGER 实例
9007199254740992 === 9007199254740993; // 为 true !!!
浏览器支持
自 2020 年 9 月以来,所有浏览器都支持 BigInt:
Chrome | Edge | Firefox | Safari | Opera |
---|---|---|---|---|
Chrome 67 | Edge 79 | Firefox 68 | Safari 14 | Opera 54 |
2018 年 5 月 | 2020 年 1 月 | 2019 年 7 月 | 2020 年 9 月 | 2018 年 6 月 |
最小和最大安全整数
ES6 向 Number 对象添加了 max 和 min 属性:
MAX_SAFE_INTEGER
MIN_SAFE_INTEGER
MAX_SAFE_INTEGER 实例
let x = Number.MAX_SAFE_INTEGER;
MIN_SAFE_INTEGER 实例
let x = Number.MIN_SAFE_INTEGER;
新的数字方法
ES6 还为 Number 对象添加了两个新方法:
Number.isInteger()
Number.isSafeInteger()
Number.isInteger() 方法
如果参数是整数,则 Number.isInteger() 方法返回 true
。
isInteger() 实例
Number.isInteger(10); Number.isInteger(10.5);
Number.isSafeInteger() 方法
安全整数是可以精确表示为双精度数的整数。
如果参数是安全整数,则 Number.isSafeInteger() 方法返回 true
。
isSafeInteger() 实例
Number.isSafeInteger(10); Number.isSafeInteger(12345678901234567890);
安全整数是从 -(253 – 1) 到 +(253 – 1) 的所有整数。
这是一个安全整数:9007199254740991。这不是一个安全整数:9007199254740992。
1.本站内容仅供参考,不作为任何法律依据。用户在使用本站内容时,应自行判断其真实性、准确性和完整性,并承担相应风险。
2.本站部分内容来源于互联网,仅用于交流学习研究知识,若侵犯了您的合法权益,请及时邮件或站内私信与本站联系,我们将尽快予以处理。
3.本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
4.根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
5.本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途
暂无评论内容