JS Number.MAX_SAFE_INTEGER 和 MAX_VALUE 有什么区别?

2022-01-14 00:00:00 integer javascript

数字.MAX_SAFE_INTEGER9007199254740991

Number.MAX_SAFE_INTEGER 9007199254740991

数字.MAX_VALUE1.7976931348623157e+308

Number.MAX_VALUE 1.7976931348623157e+308

我了解 MAX_SAFE_INTEGER 是如何基于 JavaScript 的双精度浮点算法计算的,但是这个巨大的最大值是从哪里来的呢?如果您使用所有 63 位而不是安全的 11 位作为指数,它会出现数字吗?

I understand how MAX_SAFE_INTEGER is computed based on JavaScript's double precision floating point arithmetic, but where does this huge max value come from? Is it the number that comes about if you're using all 63 bits for the exponent instead of the safe 11 bits?

推荐答案

Number.MAX_SAFE_INTEGER是计算中可以安全使用的最大整数.

Number.MAX_SAFE_INTEGER is the largest integer which can be used safely in calculations.

例如,Number.MAX_SAFE_INTEGER + 1 === Number.MAX_SAFE_INTEGER + 2 为真 - 任何大于 MAX_SAFE_INTEGER 的整数都不能始终准确地在内存中表示.所有位都用于表示数字的位数.

For example, Number.MAX_SAFE_INTEGER + 1 === Number.MAX_SAFE_INTEGER + 2 is true — any integer larger than MAX_SAFE_INTEGER cannot always be represented in memory accurately. All bits are used to represent the digits of the number.

Number.MAX_VALUE 是使用双精度浮点表示可能表示的最大数.一般来说,数字越大,准确度就越低.

Number.MAX_VALUE on the other hand is the largest number possible to represent using a double precision floating point representation. Generally speaking, the larger the number the less accurate it will be.

更多信息双精度浮点数在维基百科

相关文章