JavaScript 位运算
JavaScript 位运算符
运算符 | 名称 | 描述 |
---|---|---|
& | AND | 如果两个位都是 1,则将每个位设置为 1 |
| | OR | 如果两个位中有一个是 1,则将每个位设置为 1 |
^ | XOR | 如果两个位中只有一个是 1,则将每个位设置为 1 |
~ | NOT | 反转所有位 |
<< | 零填充左移 | 通过从右侧推入零并让最左侧的位掉落来左移 |
>> | 带符号右移 | 通过从左侧推入最左侧位的副本并让最右侧的位掉落来右移 |
>>> | 零填充右移 | 通过从左侧推入零并让最右侧的位掉落来右移 |
示例
操作 | 结果 | 等同于 | 结果 |
---|---|---|---|
5 & 1 | 1 | 0101 & 0001 | 0001 |
5 | 1 | 5 | 0101 | 0001 | 0101 |
~ 5 | 10 | ~0101 | 1010 |
5 << 1 | 10 | 0101 << 1 | 1010 |
5 ^ 1 | 4 | 0101 ^ 0001 | 0100 |
5 >> 1 | 2 | 0101 >> 1 | 0010 |
5 >>> 1 | 2 | 0101 >>> 1 | 0010 |
JavaScript 使用 32 位位运算操作数
JavaScript 将数字存储为 64 位浮点数,但所有位运算都在 32 位二进制数上执行。
在执行位运算之前,JavaScript 会将数字转换为 32 位有符号整数。
执行位运算后,结果会转换回 64 位 JavaScript 数字。
上面的示例使用 4 位无符号二进制数。因此 ~ 5 返回 10。
由于 JavaScript 使用 32 位有符号整数,它不会返回 10。它将返回 -6。
00000000000000000000000000000101 (5)
11111111111111111111111111111010 (~5 = -6)
有符号整数使用最左侧的位作为减号。
JavaScript 位运算 AND
当对一对位执行位运算 AND 时,如果两个位都是 1,则返回 1。
操作 | 结果 |
---|---|
0 & 0 | 0 |
0 & 1 | 0 |
1 & 0 | 0 |
1 & 1 | 1 |
操作 | 结果 |
---|---|
1111 & 0000 | 0000 |
1111 & 0001 | 0001 |
1111 & 0010 | 0010 |
1111 & 0100 | 0100 |
JavaScript 位运算 OR
当对一对位执行位运算 OR 时,如果两个位中有一个是 1,则返回 1
操作 | 结果 |
---|---|
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 1 |
操作 | 结果 |
---|---|
1111 | 0000 | 1111 |
1111 | 0001 | 1111 |
1111 | 0010 | 1111 |
1111 | 0100 | 1111 |
JavaScript 位运算 XOR
当对一对位执行位运算 XOR 时,如果两个位不同,则返回 1
操作 | 结果 |
---|---|
0 ^ 0 | 0 |
0 ^ 1 | 1 |
1 ^ 0 | 1 |
1 ^ 1 | 0 |
操作 | 结果 |
---|---|
1111 ^ 0000 | 1111 |
1111 ^ 0001 | 1110 |
1111 ^ 0010 | 1101 |
1111 ^ 0100 | 1011 |
JavaScript 位运算 AND (&)
位运算 AND 仅当两个位都是 1 时才返回 1
十进制 | 二进制 |
---|---|
5 | 00000000000000000000000000000101 |
1 | 00000000000000000000000000000001 |
5 & 1 | 00000000000000000000000000000001 (1) |
JavaScript 位运算 OR (|)
位运算 OR 如果两个位中有一个是 1,则返回 1
十进制 | 二进制 |
---|---|
5 | 00000000000000000000000000000101 |
1 | 00000000000000000000000000000001 |
5 | 1 | 00000000000000000000000000000101 (5) |
JavaScript 位运算 XOR (^)
位运算 XOR 如果两个位不同,则返回 1
十进制 | 二进制 |
---|---|
5 | 00000000000000000000000000000101 |
1 | 00000000000000000000000000000001 |
5 ^ 1 | 00000000000000000000000000000100 (4) |
JavaScript 位运算 NOT (~)
十进制 | 二进制 |
---|---|
5 | 00000000000000000000000000000101 |
~5 | 11111111111111111111111111111010 (-6) |
JavaScript(零填充)按位左移(<<)
这是一种零填充左移。一个或多个零位从右边被推入,最左边的位被丢弃。
十进制 | 二进制 |
---|---|
5 | 00000000000000000000000000000101 |
5 << 1 | 00000000000000000000000000001010 (10) |
JavaScript(符号保持)按位右移(>>)
这是一种符号保持右移。最左边位的副本从左边被推入,最右边的位被丢弃。
十进制 | 二进制 |
---|---|
-5 | 11111111111111111111111111111011 |
-5 >> 1 | 11111111111111111111111111111101 (-3) |
JavaScript(零填充)右移(>>>)
这是一种零填充右移。一个或多个零位从左边被推入,最右边的位被丢弃。
十进制 | 二进制 |
---|---|
5 | 00000000000000000000000000000101 |
5 >>> 1 | 00000000000000000000000000000010 (2) |
二进制数
只有设置一位的二进制数很容易理解。
二进制表示 | 十进制值 |
---|---|
00000000000000000000000000000001 | 1 |
00000000000000000000000000000010 | 2 |
00000000000000000000000000000100 | 4 |
00000000000000000000000000001000 | 8 |
00000000000000000000000000010000 | 16 |
00000000000000000000000000100000 | 32 |
00000000000000000000000001000000 | 64 |
设置更多的位揭示了二进制模式。
二进制表示 | 十进制值 |
---|---|
00000000000000000000000000000101 | 5 (4 + 1) |
00000000000000000000000000001101 | 13 (8 + 4 + 1) |
00000000000000000000000000101101 | 45 (32 + 8 + 4 + 1) |
JavaScript 二进制数以二进制补码格式存储。
这意味着负数是该数的按位非加1。
二进制表示 | 十进制值 |
---|---|
00000000000000000000000000000101 | 5 |
11111111111111111111111111111011 | -5 |
00000000000000000000000000000110 | 6 |
11111111111111111111111111111010 | -6 |
00000000000000000000000000101000 | 40 |
11111111111111111111111111011000 | -40 |
笑话
世界上只有两种人:懂二进制的和不懂二进制的。