blob: 904bffe61dba509ed2438a7f41c346878e216604 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
---
title: ビット排他的論理和 (^)
slug: Web/JavaScript/Reference/Operators/Bitwise_XOR
tags:
- ビット演算子
- JavaScript
- 言語機能
- 演算子
- Reference
browser-compat: javascript.operators.bitwise_xor
translation_of: Web/JavaScript/Reference/Operators/Bitwise_XOR
---
{{jsSidebar("Operators")}}
ビット排他的論理和演算子 (`^`) は、両方のオペランドの対応するビットの一方だけが `1` である位置のビットで `1` を返します。
{{EmbedInteractiveExample("pages/js/expressions-bitwise-xor.html")}}
## 構文
```js
a ^ b
```
## 解説
オペランドは 32 ビットの整数値に変換され、ビット (ゼロまたは 1) の並びによって表現されます。32 ビットを超える数値は最上位のビットが破棄されます。例えば、次の 32 ビットを超える整数は 32 ビット整数に変換されます。
```js
変換前: 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 |
```js
9 (10 進数) = 00000000000000000000000000001001 (2 進数)
14 (10 進数) = 00000000000000000000000000001110 (2 進数)
--------------------------------
14 ^ 9 (10 進数) = 00000000000000000000000000000111 (2 進数) = 7 (10 進数)
```
ある数 `x` と `0` のビット排他的論理和は `x` になります。
## 例
### ビット排他的論理和の使用
```js
// 9 (00000000000000000000000000001001)
// 14 (00000000000000000000000000001110)
14 ^ 9;
// 7 (00000000000000000000000000000111)
```
## 仕様書
{{Specifications}}
## ブラウザーの互換性
{{Compat}}
## 関連情報
- [ビット演算子 (JavaScript ガイド)](/ja/docs/Web/JavaScript/Guide/Expressions_and_Operators#bitwise)
- [ビット排他的論理和代入演算子](/ja/docs/Web/JavaScript/Reference/Operators/Bitwise_XOR_assignment)
|