Atomics -compareExchange() 方法
如果给定值与旧值不同,compareExchange方法会比较并交换替换值。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。
句法
Atomics.compareExchange(typedArray, index, expectedValue, replacementValue)
参数
typedArray是整数类型数组。
索引是类型数组中的位置。
用于检查相等性的预期值。
交换价值。
返回
返回给定位置的旧值。
例外情况
如果传递的数组不是整数类型数组,则会出现TypeError 。
如果传递的索引在类型化数组中超出范围,则出现RangeError 。
例子
以下是实现 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 Example</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"); // create a SharedArrayBuffer var buffer = new SharedArrayBuffer(25); var arr = new Uint8Array(buffer); // Initialise element at zeroth position of array with 6 arr[0] = 6; container.innerHTML = Atomics.compareExchange(arr, 0, 6, 2) + '<br/>' + Atomics.load(arr, 0); } </script> </body> </html>
输出
验证结果。