ECMAScript 6' s Number.MAX_SAFE_INTEGER
应该代表JavaScript在浮点精度出现问题之前可以存储的最大数值。但是,要求添加到此值的数字1也必须表示为Number
。
Number.MAX_SAFE_INTEGER
注意
Number.MAX_SAFE_INTEGER
的值是最大整数n
,因此n
和n + 1
都可以完全表示为Number
值。
Number.MAX_SAFE_INTEGER
的值为9007199254740991 (2^53−1)
。
Chrome,Firefox,Opera和IE11的JavaScript控制台都可以安全地执行数字9,007,199,254,740,992的计算。一些测试:
// Valid
Math.pow(2, 53) // 9007199254740992
9007199254740991 + 1 // 9007199254740992
9007199254740992 - 1 // 9007199254740991
9007199254740992 / 2 // 4503599627370496
4503599627370496 * 2 // 9007199254740992
parseInt('20000000000000', 16) // 9007199254740992
parseInt('80000000000', 32) // 9007199254740992
9007199254740992 - 9007199254740992 // 0
9007199254740992 == 9007199254740991 // false
9007199254740992 == 9007199254740992 // true
// Erroneous
9007199254740992 + 1 // 9007199254740992
9007199254740993 + "" // "9007199254740992"
9007199254740992 == 9007199254740993 // true
为什么n + 1
必须也可以表示为Number
?为什么失败会使值不安全?
答案 0 :(得分:32)
我想说的是因为虽然Math.pow(2, 53)
是最大的可直接表示的整数,但它的不安全,因为它的第一个值表示也是另一个值的近似值:
9007199254740992 == 9007199254740993 // true
与Math.pow(2, 53) - 1
:
9007199254740991 == 9007199254740993 // false
答案 1 :(得分:0)
唯一靠近另一个的数字 与下一个数字比较时显示为真
9007199254740992 == 9007199254740993
true
9007199254740993 == 9007199254740994
false
9007199254740991 == 9007199254740992
false
9007199254740997 == 9007199254740998
false