位运算(与、或、异或、取反、右移、左移)

1、按位与(&)

对两个数进行操作,然后返回一个新的数,这个数的每个位都需要两个输入数的同一位都为1时才为1,如下图:

(A & B) 结果为 12, 二进制为 0000 1100

 

2、按位或(|)

比较两个数,然后返回一个新的数,这个数的每一位设置1的条件是两个输入数的同一位都不为0(即任意一个为1,或都为1),如下图:

(A | B) 结果为 61, 二进制为 0011 1101

 

 

3、按位异或(^)

比较两个数,然后返回一个数,这个数的每个位设为1的条件是两个输入数的同一位不同,如果相同就设为0,如下图:

(A ^ B) 结果为 49, 二进制为 0011 0001

 

 

4、按位取反(~)

对一个操作数的每一位都取反,如下图:

(~A ) 结果为 -61, 二进制为 1100 0011

 

 

5、按位左移(<<)

将操作数的所有位向左移动指定的位数。

下图展示了11111111 << 1(11111111 左移一位)的结果。蓝色数字表示被移动位,灰色表示被丢弃位,空位用橙色的0填充。

(A << 2)结果为 240, 二进制为 1111 0000

 

 

6、按位右移(<<)

将操作数的所有位向又移动指定的位数。

下图展示了11111111 >> 1(11111111 右移一位)的结果。蓝色数字表示被移动位,灰色表示被丢弃位,空位用橙色的0填充。

A >> 2 结果为 15, 二进制为 0000 1111

 

 

 

 

 

 

猜你喜欢

转载自blog.csdn.net/qq_41661919/article/details/81122365