按位异或 (^)
按位异或 (^
) 运算符返回一个数字或 BigInt,其二进制表示中,当且仅当两个操作数中相应的位有一个是 1
时,该位才为 1
。
试一试
const a = 5; // 00000000000000000000000000000101
const b = 3; // 00000000000000000000000000000011
console.log(a ^ b); // 00000000000000000000000000000110
// Expected output: 6
语法
js
x ^ y
描述
^
运算符对两种类型的操作数进行了重载:number 和 BigInt。对于数字,该运算符返回一个 32 位整数。对于 BigInt,该运算符返回一个 BigInt。它首先将两个操作数强制转换为数值,然后测试它们的类型。如果两个操作数都变为 BigInt,则执行 BigInt 异或;否则,它将两个操作数转换为32 位整数并执行数字按位异或。如果一个操作数变为 BigInt 而另一个变为 number,则抛出 TypeError
。
该运算符以二进制补码形式对操作数的位表示进行操作。第一个操作数中的每个位与第二个操作数中的相应位配对:*第一个位*与*第一个位*,*第二个位*与*第二个位*,依此类推。该运算符应用于每对位,结果按位构造。
异或运算的真值表是
x | y | x 异或 y |
---|---|---|
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 0 |
9 (base 10) = 00000000000000000000000000001001 (base 2) 14 (base 10) = 00000000000000000000000000001110 (base 2) -------------------------------- 14 ^ 9 (base 10) = 00000000000000000000000000000111 (base 2) = 7 (base 10)
超过 32 位的数字将丢弃其最高有效位。例如,以下超过 32 位的整数将被转换为 32 位整数
Before: 11100110111110100000000000000110000000000001 After: 10100000000000000110000000000001
警告: 你可能会看到有人使用 ^ 0
将数字截断为整数。将任何数字 x
与 0
进行按位异或会返回转换为 32 位整数的 x
,这会额外移除超出 -2147483648 到 2147483647 范围的数字的前导位。请改用 Math.trunc()
。
对于 BigInt,没有截断。从概念上讲,将正 BigInt 理解为具有无限数量的前导 0
位,将负 BigInt 理解为具有无限数量的前导 1
位。
示例
使用按位异或
js
// 9 (00000000000000000000000000001001)
// 14 (00000000000000000000000000001110)
14 ^ 9;
// 7 (00000000000000000000000000000111)
14n ^ 9n; // 7n
规范
规范 |
---|
ECMAScript® 2026 语言规范 # prod-BitwiseXORExpression |
浏览器兼容性
加载中…