Atomics.notify()

Baseline 已广泛支持

此功能已成熟,可在多种设备和浏览器版本上使用。自 2021 年 12 月以来,它已在所有浏览器中可用。

Atomics.notify() 静态方法会唤醒等待队列中处于睡眠状态的某些代理。

注意:此操作仅适用于查看 SharedArrayBufferInt32ArrayBigInt64Array。在非共享 ArrayBuffer 对象上,它将返回 0

语法

js
Atomics.notify(typedArray, index, count)

参数

typedArray

一个查看 SharedArrayBufferInt32ArrayBigInt64Array

index

typedArray 中唤醒的**位置**。

count 可选

要通知的睡眠代理的**数量**。默认为 Infinity

返回值

返回被唤醒的代理的数量,如果 typedArray 是非共享 ArrayBuffer 的视图,则返回 0

异常

TypeError

如果 typedArray 不是 Int32ArrayBigInt64Array,则会**抛出**此错误。

RangeError

如果 indextypedArray 中超出界限,则抛出。

示例

使用 notify

给定一个共享的 Int32Array

js
const sab = new SharedArrayBuffer(1024);
const int32 = new Int32Array(sab);

读取线程正在位置 0 上睡眠并等待,因为提供的 value 与在提供的 index 处存储的值匹配。读取线程在写入线程调用所提供的 typedArray 的位置 0 上的 Atomics.notify() 之前不会继续。请注意,如果被唤醒后,位置 0 的值没有被写入线程更改,读取线程**不会**重新进入睡眠,而是会继续执行。

js
Atomics.wait(int32, 0, 0);
console.log(int32[0]); // 123

写入线程存储一个新值,并在写入后通知等待线程

js
console.log(int32[0]); // 0;
Atomics.store(int32, 0, 123);
Atomics.notify(int32, 0, 1);

规范

规范
ECMAScript® 2026 语言规范
# sec-atomics.notify

浏览器兼容性

另见