在 ES10 中,BigInt 成为了一种新的原始数据类型,它可以表示任意大的整数,解决了 JavaScript 中 Number 类型的精度问题。BigInt 支持基本运算操作,比如加、减、乘、除等,但是它的运算和使用也需要特别注意,以避免运算错误。本文将介绍 BigInt 的运算及其使用技巧,帮助读者深入了解这个新的数据类型,并避免 BigInt 运算错误的发生。
BigInt 的定义
在 ES10 中,BigInt 是一种新的原始数据类型,表示任意大的整数。BigInt 采用 n
后缀来表示,例如 10n
、10000000000n
等。
const num = 1234567890123456789012345678901234567890n; console.log(num); // 1234567890123456789012345678901234567890n
BigInt 支持基本运算符号和方法,包括加、减、乘、除、求余数等。BigInt 的加、减、乘、除和 Number 的运算符号相同,除了除法运算采用 n / bignum
这样的形式。同时 BigInt 还提供了一个新的运算符号 **
,用于求幂操作。
BigInt 的运算
在 JavaScript 中,如果对一个 Number 类型的数求余数,通常会使用 %
运算符。但是对于 BigInt,%
运算符是不适用的。BigInt 提供了一个新的方法 BigInt.prototype.mod()
来计算余数。
const a = 12345678901234567890n; const b = 1234n; console.log(a.mod(b)); // 750n
BigInt 的加、减、乘、除等运算符和方法都与 Number 类型的运算相似。但是需要注意的一点是,当 BigInt 和 Number 类型进行运算时,BigInt 会先将 Number 类型转化为 BigInt 类型,再进行运算。因此,运算结果的类型是 BigInt。
const a = 12345678901234567890n; const b = 1234; console.log(a + b); // 12345678901234569124n
BigInt 实例和 Number 类型的解构赋值也可以一起使用。
const [a, b] = [12345678901234567890n, 1234]; console.log(a + b); // 12345678901234569124n
BigInt 和 Number 类型进行运算时,也存在一些坑点。比如下面这个例子:
const a = 12345678901234567890n; const b = Number.MAX_SAFE_INTEGER; console.log(a + b); // 12345678901234569988n
可以发现,BigInt 和 Number 类型相加时,BigInt 的数值并未溢出,但是由于 Number 类型的精度限制,加法运算不再准确。如果希望精确计算,需要将 Number 类型转换为 BigInt 类型。
const a = 12345678901234567890n; const b = BigInt(Number.MAX_SAFE_INTEGER); console.log(a + b); // 12345678901234567898n
BigInt 的扩展和避坑
BigInt 是一个新的数据类型,它目前还没有得到广泛的支持。因此,在使用 BigInt 进行编程时,需要引入相应的插件或者运行时环境,比如 BigInt.js、Node.js 等。
同时还需要注意避免一些常见的 BigInt 运算错误。下面是一些常见的 BigInt 运算错误及其解决方案:
错误:使用 Number.MAX_SAFE_INTEGER 时,精度不够
当使用 Number.MAX_SAFE_INTEGER 时,精度不够,结果会出现错误。
const bigNum = 1234567890123456789012345678901234567890n; const num = Number.MAX_SAFE_INTEGER; console.log(bigNum + num); // 12345678901234569164n,结果有误
解决方案:将 Number.MAX_SAFE_INTEGER 转化为 BigInt 类型
const bigNum = 1234567890123456789012345678901234567890n; const num = BigInt(Number.MAX_SAFE_INTEGER); console.log(bigNum + num); // 12345678901234567898n,结果正确
错误:使用 Number 类型进行位运算时,结果不正确
当使用 Number 类型进行位运算时,结果不正确。
const bigNum = 1234567890123456789012345678901234567890n; console.log(bigNum >> 1); // 618283945061728394506172839450617282012n,结果有误
解决方案:使用 BigInt 类型进行位运算
const bigNum = 1234567890123456789012345678901234567890n; console.log(bigNum >> 1n); // 617283945061728394506172839450617282012n,结果正确
错误:在使用 BigInt 时,需要注意数据类型
由于 BigInt 是一个新的数值类型,可能会在一些函数中传递出错。
function logNum(num) { console.log(num); } logNum(12345678901234567890n); // 正确 logNum(12345678901234567890); // 错误:Number 类型
解决方案:在函数中使用 BigInt 类型
function logNum(num) { console.log(num); } logNum(BigInt(12345678901234567890)); // 正确
结论
BigInt 是一种新的原始数据类型,可以表示任意大的整数,解决了 JavaScript 中 Number 类型的精度问题。BigInt 支持大部分的基本运算符号和方法,但是需要注意 BigInt 和 Number 类型进行运算时的精度问题。同时,使用 BigInt 进行编程时需要引入相应的插件或者运行时环境,还需要注意避免一些常见的运算错误。掌握 BigInt 的运算和避坑技巧,可以方便地使用 BigInt 进行编程,避免运算错误的发生。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/67353dcd0bc820c5824d4e77