Atomics.isLockFree()

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since December 2021.

Die statische Methode Atomics.isLockFree() wird verwendet, um zu bestimmen, ob die Atomics-Methoden Sperren oder atomare Hardware-Operationen verwenden, wenn sie auf typisierte Arrays mit einer bestimmten Byte-Größe angewendet werden. Sie ist als Optimierungsprimitive gedacht, damit leistungsstarke Algorithmen entscheiden können, ob sie Sperren oder atomare Operationen in kritischen Abschnitten verwenden sollen. Wenn ein atomarer Primitive nicht sperrfrei ist, ist es oft effizienter, wenn ein Algorithmus eigene Sperrmechanismen bereitstellt.

Probieren Sie es aus

console.log(Atomics.isLockFree(3));
// 3 is not one of the BYTES_PER_ELEMENT values
// Expected output: false

console.log(Atomics.isLockFree(4));
// 4 is one of the BYTES_PER_ELEMENT values
// Expected output: true

Syntax

js
Atomics.isLockFree(size)

Parameter

size

Die Größe in Bytes, die geprüft werden soll.

Rückgabewert

Ein true- oder false-Wert, der angibt, ob die Operation sperrfrei ist.

  • Immer true, wenn size 4 ist, da alle bekannten Plattformen 4-Byte-atomare Operationen unterstützen.
  • Immer false, wenn die angegebene Größe nicht eine der BYTES_PER_ELEMENT-Eigenschaften von Integer-TypedArray-Typen ist.

Beispiele

Verwendung von isLockFree

js
Atomics.isLockFree(1); // true (platform-dependent)
Atomics.isLockFree(2); // true (platform-dependent)
Atomics.isLockFree(3); // false
Atomics.isLockFree(4); // true
Atomics.isLockFree(5); // false
Atomics.isLockFree(6); // false
Atomics.isLockFree(7); // false
Atomics.isLockFree(8); // true (platform-dependent)

Spezifikationen

Specification
ECMAScript® 2025 Language Specification
# sec-atomics.islockfree

Browser-Kompatibilität

Report problems with this compatibility data on GitHub
desktopmobileserver
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
Deno
Node.js
isLockFree

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support

Siehe auch