算法数据结构编译原理

位运算符操作

2019-03-25  本文已影响0人  介和

转载:https://jingyan.baidu.com/article/1612d5008ff5b7e20f1eee4c.html

按位与(&)

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

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

按位或(|)

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

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

按位异或(^)

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

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

按位取反(~)

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

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

按位左移(<<)

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

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

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

按位右移(<<)

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

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

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

上一篇下一篇

猜你喜欢

热点阅读