前端面试 JavaScript— 什么是BigInt? 谈谈你对它的认识
Posted aiguangyuan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端面试 JavaScript— 什么是BigInt? 谈谈你对它的认识相关的知识,希望对你有一定的参考价值。
1. 什么是BigInt?
BigInt是一种新的数据类型,用于当整数值大于Number数据类型支持的范围时。这种数据类型允许我们安全地对大整数执行算术操作,表示高分辨率的时间戳,使用大整数ID等等,而不需要使用库。
2. 为什么需要BigInt?
在JS中,所有的数字都以双精度64位浮点格式表示,那这会带来什么问题呢?
这导致JS中的Number无法精确表示非常大的整数,它会将非常大的整数四舍五入,确切地说,JS中的 Number类型只能安全地表示-9007199254740991(-(2^53-1))和9007199254740991((2^53-1)),任何超出此范围的整数值都可能失去精度。
console.log(9999999999999999999);
// 10000000000000000000
同时也会有一定的安全性问题:
console.log(9007199254740992 === 9007199254740993);
// true 居然是true!
3. 如何创建并使用BigInt?
要创建BigInt,只需要在数字末尾追加n即可。
console.log(9007199254740995);
// 9007199254740996
console.log(9007199254740995n);
// 9007199254740995n
另一种创建BigInt的方法是用BigInt()构造函数。
var num = BigInt("9007199254740995");
console.log(num);
// 9007199254740995n
简单使用如下:
console.log(10n + 20n);
// 30n
console.log(10n - 20n);
// -10n
console.log(-10n);
// -10n
console.log(10n * 20n);
// 200n
console.log(20n / 10n);
// 2n
console.log(23n % 10n);
// 3n
console.log(10n ** 3n);
// 1000n
let x = 10n;
console.log(++x);
// 11n
console.log(--x);
// 10n
console.log(typeof x);
// bigint
console.log(+10n);
// TypeError: Cannot convert a BigInt value to a number
需要注意的事项:
1. BigInt不支持一元加号运算符,这可能是某些程序可能依赖于 + 始终生成 Number 的不变量,或者抛出异常。另外,更改 + 的行为也会破坏 asm.js代码;
2. 因为隐式类型转换可能丢失信息,所以不允许在 bigint 和 Number 之间进行混合操作。当混合使用大整数和浮点数时,结果值可能无法由BigInt或Number精确表示;
console.log(10 + 20n);
// Uncaught TypeError: Cannot mix BigInt and other types, use explicit conversions
3. 不能将BigInt传递给Web api 和内置的 JS 函数,这些函数需要一个 Number 类型的数字,尝试这样做会报TypeError错误;
Math.max(2n, 4n, 6n);
// Uncaught TypeError: Cannot convert a BigInt value to a number
4. 当 Boolean 类型与 BigInt 类型相遇时,BigInt的处理方式与Number类似,换句话说,只要不是 0n,BigInt就被视为truthy的值;
if(0n){
// 判断为false
}
if(3n){
// 判断为true
}
5. 元素都为BigInt的数组可以进行sort排序;
6. BigInt可以正常地进行位运算,如 |、&、> 和 ^。
浏览器兼容性
Caniuse 前端兼容性工具查询的结果:
主流的浏览器几乎都支持了,但要成为规范,还要很长的路要走。
以上是关于前端面试 JavaScript— 什么是BigInt? 谈谈你对它的认识的主要内容,如果未能解决你的问题,请参考以下文章
前端面试 JavaScript— == 和 ===有什么区别?