このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docsコミュニティーについてもっと知り、仲間になるにはこちらから。
Atomics.xor()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2021年12月.
Atomics.xor() は静的メソッドで、配列内の指定した位置にある指定された値とのビット単位の XOR を計算し、その位置にあった古い値を返します。これは不可分操作であり、変更された値が書き戻されるまで他の書き込みが行われないことが保証されます。
In this article
試してみましょう
// バイト単位でサイズを指定して SharedArrayBuffer を作成const buffer = new SharedArrayBuffer(16);const uint8 = new Uint8Array(buffer);uint8[0] = 7;// 7 (0111) XOR 2 (0010) = 5 (0101)console.log(Atomics.xor(uint8, 0, 2));// 予想される結果: 7console.log(Atomics.load(uint8, 0));// 予想される結果: 5構文
js
Atomics.xor(typedArray, index, value)引数
typedArray整数の型付き配列です。
Int8Array、Uint8Array、Int16Array、Uint16Array、Int32Array、Uint32Array、BigInt64Array、BigUint64Arrayのいずれかです。indextypedArrayの中でビット単位の XOR を計算する位置です。valueビット単位の XOR を計算する値です。
返値
指定された位置にあった古い値 (typedArray[index]) です。
例外
TypeErrortypedArrayが許可された整数型のいずれでもない場合に発生します。RangeErrorindexがtypedArrayの範囲を超えている場合に発生します。
解説
ビット単位の XOR 演算は、a とb が異なる場合に 1 になります。XOR 演算の真理値表は次の通りです。
a | b | a ^ b |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |
例えば、ビット単位の XOR では5 ^ 1 の結果が0100、すなわち 10 進数で 4 になります。
5 01011 0001 ----4 0100
例
>xor の使用
js
const sab = new SharedArrayBuffer(1024);const ta = new Uint8Array(sab);ta[0] = 5;Atomics.xor(ta, 0, 1); // 古い値である 5 を返すAtomics.load(ta, 0); // 4仕様書
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-atomics.xor> |