Java 位运算(移位、位与、或、异或、非)
对位操作的不熟悉,因此需要这篇文章进行参考,但是只提到了最常用的一些操作:左移( << )、右移( >> )、位与( & ) 、位或( | )、位非( ~ )、位异或( ^ ),除了位非( ~ )是一元操作符外,其它的都是二元操作符。
转载自:CSDN:
Java 位运算(移位、位与、或、异或、非)
1、左移( << )
Test1、将5左移2位:
public class Test { public static void main(String[] args) { System.out.println(5<<2);//运行结果是20 } }
运行结果是20,但是程序是怎样执行的呢?
首先会将5转为2进制表示形式(java中,整数默认就是int类型,也就是32位):
0000 0000 0000 0000 0000 0000 0000 0101 然后左移2位后,低位补0:
0000 0000 0000 0000 0000 0000 0001 0100 换算成10进制为20
2、右移( >> ) ,右移同理,只是方向不一样
System.out.println(5>>2);//运行结果是1
还是先将5转为2进制表示形式:
0000 0000 0000 0000 0000 0000 0000 0101 然后右移2位,高位补0:
0000 0000 0000 0000 0000 0000 0000 0001
3、位与( & )
public class Test { public static void main(String[] args) { System.out.println(5 & 3);//结果为1 } }
还是老套路,将2个操作数和结果都转换为二进制进行比较:
5转换为二进制:0000 0000 0000 0000 0000 0000 0000 0101
3转换为二进制:0000 0000 0000 0000 0000 0000 0000 0011
-------------------------------------------------------------------------------------
1转换为二进制:0000 0000 0000 0000 0000 0000 0000 0001
位与:第一个操作数的的第n位于第二个操作数的第n位如果都是1,那么结果的第n为也为1,否则为0
4、位或( | )
public class Test { public static void main(String[] args) { System.out.println(5 | 3);//结果为7 } }
5转换为二进制:0000 0000 0000 0000 0000 0000 0000 0101
3转换为二进制:0000 0000 0000 0000 0000 0000 0000 0011
-------------------------------------------------------------------------------------
7转换为二进制:0000 0000 0000 0000 0000 0000 0000 0111
位或操作:第一个操作数的的第n位于第二个操作数的第n位 只要有一个是1,那么结果的第n为也为1,否则为0
5、位异或( ^ )
public class Test { public static void main(String[] args) { System.out.println(5 ^ 3);//结果为6 } }
5转换为二进制:0000 0000 0000 0000 0000 0000 0000 0101
3转换为二进制:0000 0000 0000 0000 0000 0000 0000 0011
-------------------------------------------------------------------------------------
6转换为二进制:0000 0000 0000 0000 0000 0000 0000 0110
位异或:第一个操作数的的第n位于第二个操作数的第n位 相反,那么结果的第n为也为1,否则为0
6、位非( ~ )
public class Test { public static void main(String[] args) { System.out.println(~5);//结果为-6 } }
5转换为二进制:0000 0000 0000 0000 0000 0000 0000 0101
-------------------------------------------------------------------------------------
-6转换为二进制:1111 1111 1111 1111 1111 1111 1111 1010
位非:操作数的第n位为1,那么结果的第n位为0,反之。
数值在内存中是以补码形式存储的。正数的补码是其本身,负数的补码是其原码取反+1