Number.MAX_SAFE_INTEGER

Baseline 已廣泛支援

此特性已相當成熟,可在許多裝置和瀏覽器版本上使用。自 2015 年 9 月以來,該特性已在各大瀏覽器中可用。

Number.MAX_SAFE_INTEGER 靜態資料屬性表示 JavaScript 中的最大安全整數 (253 – 1)。

對於更大的整數,請考慮使用 BigInt

試一試

const x = Number.MAX_SAFE_INTEGER + 1;
const y = Number.MAX_SAFE_INTEGER + 2;

console.log(Number.MAX_SAFE_INTEGER);
// Expected output: 9007199254740991

console.log(x);
// Expected output: 9007199254740992

console.log(x === y);
// Expected output: true

9007199254740991 (9,007,199,254,740,991,或約 9 千萬億)。

Number.MAX_SAFE_INTEGER 的屬性特性
可寫
可列舉
可配置

描述

雙精度浮點格式僅有 52 位來表示 尾數,因此它只能安全地表示 -(253 – 1) 和 253 – 1 之間的整數。“安全”在此上下文中指的是能夠精確表示整數並正確比較它們的能力。例如,Number.MAX_SAFE_INTEGER + 1 === Number.MAX_SAFE_INTEGER + 2 將計算為 true,這在數學上是不正確的。有關更多資訊,請參閱 Number.isSafeInteger()

由於 MAX_SAFE_INTEGERNumber 的靜態屬性,您始終將其用作 Number.MAX_SAFE_INTEGER,而不是作為數字值的屬性。

示例

MAX_SAFE_INTEGER 的返回值

js
Number.MAX_SAFE_INTEGER; // 9007199254740991

MAX_SAFE_INTEGER 和 EPSILON 之間的關係

Number.EPSILON 是 2-52,而 MAX_SAFE_INTEGER 是 253 – 1 — 兩者都源自尾數的寬度,即 53 位(最高位始終為 1)。將它們相乘會得到一個非常接近 — 但不等於 — 2 的值。

js
Number.MAX_SAFE_INTEGER * Number.EPSILON; // 1.9999999999999998

規範

規範
ECMAScript® 2026 語言規範
# sec-number.max_safe_integer

瀏覽器相容性

另見