1.<<(左移)

将数字的位向左移动指定的位数(二进制表示);

例:2<<2输出8

2的二进制表示为10,向左移动2位为1000,十进制为8.

2.>>(右移)

将数字的位向右移动指定的位数(二进制表示);

例:11>>1输出5

11的二进制表示为1011,向右移动1位为101,十进制为5.

3.&(按位与)

将数字(二进制)对应位数比较,若对应位都为1,则对应位为1,否则为0;

例:5&3输出1

5的二进制为101,3的二进制为011,按位与结果为001,十进制为1.

4.|(按位或)

将数字(二进制)对应位数比较,若对应位至少有一个为1,则对应位为1,若对应位都为0,则对应位为0;

例:5|3输出7

5的二进制为101,3的二进制为011,按位或结果为111,十进制为7.

5.^(按位异或)

将数字(二进制)对应位数比较,若对应位只有一个为1,则对应位为1,否则对应位为0;

例:5^3输出6

5的二进制为101,3的二进制为011,按位或结果为110,十进制为6.

6.~(按位取反)

计算机内部在做数学运算时(也就是计算机的0和1的运算),都是以补码为标准的,说白了计算机中就一种码那就是补码,而现实社会中的编码规则,例如原码、反码都是我们自定义的,为了和计算机中的补码形成转换关系。所以说在我们手工计算这类由计算机计算的01运算,要站在计算机的角度。因此首先就要将我们的原码反码全都先转为补码,再来计算.

正数的原、反、补码都是它本身;负数的原码最高位为1开头,反码是最高符号位不变,其余位在原码的基础上取反,补码是在反码的基础上+1即可得到.

例:~5输出6

5的补码:00000101

00000101按位取反,取反结果为: 11111010

这里的结果是用补码表示的,还是机器表示形式,转化为自然语言的编码,把结果转化为原码:

补码-1转为反码: 11111010 - 1 = 11111001

反码再取反转为原码:11111001 = 10000110

原码转为十进制,答案就是-6.

x按位取反运算公式为: -(x+1)