此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。

View in English Always switch to English

Atomics.compareExchange()

基线 广泛可用

自 2021年12月 起,此特性已在主流浏览器中得到支持,可在大多数设备和浏览器版本中正常使用。

如果给定的预期值等于旧值,Atomics.exchange() 静态方法会用给定的值替换数组上指定位置的值,并返回该位置的旧值,无论其是否等于预期的值。此原子操作保证在修改后的值写回之前不会发生其他写操作。

尝试一下

// Create a SharedArrayBuffer with a size in bytes
const buffer = new SharedArrayBuffer(16);
const uint8 = new Uint8Array(buffer);
uint8[0] = 5;

Atomics.compareExchange(uint8, 0, 5, 2); // Returns 5
console.log(Atomics.load(uint8, 0));
// Expected output: 2

Atomics.compareExchange(uint8, 0, 5, 4); // Returns 2
console.log(Atomics.load(uint8, 0));
// Expected output: 2

语法

js
Atomics.compareExchange(typedArray, index, expectedValue, replacementValue)

参数

typedArray

一个整数类型数组。Int8ArrayUint8ArrayInt16ArrayUint16ArrayInt32ArrayUint32ArrayBigInt64ArrayBigUint64Array 之一。

index

typedArray 中的要替换为 replacementValue 的位置。

expectedValue

用于检查相等性的值。

replacementValue

要替换的值。

返回值

给定位置的旧值(typedArray[index])。

异常

TypeError

如果 typedArray 不是允许的整数类型数组之一,则抛出该异常。

RangeError

如果 index 超出 typedArray 的范围,则抛出该异常。

示例

使用 compareExchange()

js
const sab = new SharedArrayBuffer(1024);
const ta = new Uint8Array(sab);
ta[0] = 7;

Atomics.compareExchange(ta, 0, 7, 12); // 返回 7,即旧的值
Atomics.load(ta, 0); // 12

规范

规范
ECMAScript® 2027 Language Specification
# sec-atomics.compareexchange

浏览器兼容性

参见