JavaScript中的基本數據類Number是雙精度浮點數,它可以表示的最大安全范圍是正負9007199254740991,也就是2的53次方減一,在瀏覽器控制臺分別輸入Number.MAX_SAFE_INTEGER和Number.MIN_SAFE_INTEGER可查看對應的最大/小值
const max = Number.MAX_SAFE_INTEGER; // → 9_007_199_254_740_991 // 注意:為了便于閱讀,我使用下劃線作為分隔符將這些數字分組為千位數。數字文字分隔符提案對普通的JavaScript數字文字使用正確。
將這個最大值加一,可以得到預期的結果:
max + 1;// → 9_007_199_254_740_992 ✅
但是,如果我們再次增加它,結果不再可以完全表示為JavaScript Number:
max + 2;// → 9_007_199_254_740_992 ❌
我們會發現max+1和max+2的結果一樣。只要我們在JavaScript中獲得這個特定的值,就無法判斷它是否準確。對安全整數范圍以外的整數(即從Number.MIN_SAFE_INTEGER到Number.MAX_SAFE_INTEGER)的任何計算可能會失去精度。出于這個原因,我們只能依靠安全范圍內的數字整數值。
BigInt
BigInt是JavaScript中的一個新的原始類型,可以用任意精度表示整數。使用BigInt,即使超出JavaScript Number 的安全整數限制,也可以安全地存儲和操作大整數。
chrome 67+開始支持BigInt,本文所有demo都是基于chrome 67。
要創建一個BigInt,在數字后面添加n后綴即可,例如,123變成123n。全局BigInt(number)函數可以用來將Number轉換成BigInt。換句話說,BigInt(123) === 123n。讓我們用這兩種技術來解決我們之前遇到的問題:
BigInt(Number.MAX_SAFE_INTEGER) + 2n;// → 9_007_199_254_740_993n ✅
我們將兩個Number 相乘:
1234567890123456789 * 123;// → 151851850485185200000 ❌
查看上面兩個數字,末尾分別是9和3,9*3=27,然而結果末尾卻是000,明顯是錯誤的,讓我們用BigInt代替:
1234567890123456789n * 123n;// → 151851850485185185047n ✅
這次我們得到了正確的結果。
Number 的安全整數限制不適用于BigInt。因此,BigInt我們可以執行正確的整數運算而不必擔心失去精度。
BigInt是JavaScript語言中的一個原始類型。因此,可以使用typeof操作符檢測到這種類型:
typeof 123;// → 'number'typeof 123n;// → 'bigint'
因為BigInts是一個單獨的類型,所以a BigInt永遠不會等于a Number,例如 42n !== 42。要比較a BigInt和a Number,在比較之前將其中一個轉換為另一個的類型或使用abstract equal(==):
42n === BigInt(42);// → true42n == 42;// → true
當強制轉換為布爾型(使用if,&&,||,或Boolean(int)),BigInt按照和Number相同的邏輯轉換。
新聞熱點
疑難解答
圖片精選