ビット排他的論理和 (^)

ビット排他的論理和演算子 (^) は、両方のオペランドの対応するビットの一方だけが 1 である位置のビットで 1 を返します。

構文

a ^ b

解説

オペランドは32ビットの整数値に変換され、ビット (ゼロまたは1) の並びによって表現されます。32ビットを超える数値は最上位のビットが破棄されます。例えば、次の32ビットを超える整数は32ビット整数に変換されます。

変換前: 11100110111110100000000000000110000000000001
変換後:             10100000000000000110000000000001

第1オペランドの各ビットは、第2オペランドの対応するビットと組み合わせになります。第1ビット第1ビットへ、第2ビット第2ビットへ、という具合にです。

この演算子は各ビットの組み合わせに適用され、結果はビット単位に構築されます。

XOR 演算の真理値表は次のようになります。

a b a XOR b
0 0 0
0 1 1
1 0 1
1 1 0
.    9 (10進数) = 00000000000000000000000000001001 (2進数)
    14 (10進数) = 00000000000000000000000000001110 (2進数)
                   --------------------------------
14 ^ 9 (10進数) = 00000000000000000000000000000111 (2進数) = 7 (10進数)

ある数 x0 のビット排他的論理和は x になります。

ビット排他的論理和の使用

// 9  (00000000000000000000000000001001)
// 14 (00000000000000000000000000001110)

14 ^ 9; 
// 7  (00000000000000000000000000000111)

仕様

仕様書
ECMAScript (ECMA-262)
Bitwise XOR expression の定義

ブラウザーの互換性

Update compatibility data on GitHub
デスクトップモバイルサーバー
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewAndroid 版 ChromeAndroid 版 FirefoxAndroid 版 OperaiOSのSafariSamsung InternetNode.js
Bitwise XOR (a ^ b)Chrome 完全対応 1Edge 完全対応 12Firefox 完全対応 1IE 完全対応 3Opera 完全対応 3Safari 完全対応 1WebView Android 完全対応 1Chrome Android 完全対応 18Firefox Android 完全対応 4Opera Android 完全対応 10.1Safari iOS 完全対応 1Samsung Internet Android 完全対応 1.0nodejs 完全対応 0.1.100

凡例

完全対応  
完全対応

関連情報