Atomics compareExchange() 方法
比较交换 如果给定值与旧值不同,该方法将比较并交换替换值。它返回该位置的旧值。这个Atomics 操作确保在修改的值被写回之前不会发生其他写入。
语法
Atomics.compareExchange(typedArray, index, expectedValue, replacementValue)
参数
-
类型化数组 是整数类型数组。
-
index 是类型数组中的位置。
-
期望值 检查是否相等。
-
替换值 交换。
Return
返回给定位置的旧值。
例外
-
类型错误 如果传递的数组不是整数类型的数组。
-
范围错误 如果传递的索引在类型化数组中超出范围。
例子
下面是实现 JavaScript Atomics 的代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Atomics 例子</title> <style> .result { font-size: 20px; border: 1px solid black; } </style> </head> <body onLoad="operate();"> <h1>JavaScript Atomics Properties</h1> <div class="result"></div> <p>Atomics.compareExchange(arr, 0, 6, 2)</p> <p>Atomics.load(arr, 0)</p> <script> function operate(){ let container = document.querySelector(".result"); // 创建一个 SharedArrayBuffer var buffer = new SharedArrayBuffer(25); var arr = new Uint8Array(buffer); // 用 6 初始化数组第零位的元素 arr[0] = 6; container.innerHTML = Atomics.compareExchange(arr, 0, 6, 2) + '<br/>' + Atomics.load(arr, 0); } </script> </body> </html>
输出
验证结果。