Java中的位运算

Java提供的位运算符有:左移(<<)、右移(>>)、无符号右移(>>>)、位与(&)、位或(|)、位非(~)、位异或(^),除了位非( ~)是一元操作符外,其它的都是二元操作符。

1 左移 ( << )

System.out.println(5<<2); // 20


步骤1:将5转为2进制表示形式,java中int类型4个字节32位

步骤2:左移2位后低位补0

0000 0000 0000 0000 0000 0000 0000 0101

0000 0000 0000 0000 0000 0000 0001 0100

在数字没有溢出前提下,对于正数和负数,左移一位都相当于乘以2的1次方,左移n位就相当于乘以2的n次方。



2 右移 ( >> )

System.out.println(5>>2); // 1 


步骤1:5转为2进制表示

步骤2:右移2位,高位补0

0000 0000 0000 0000 0000 0000 0000 0101

0000 0000 0000 0000 0000 0000 0000 0001

右移一位相当于除2,右移n位相当于除以2的n次方。



3 无符号右移 ( >>> )

Java中int类型占32位,可表示一个正数,也可表示一个负数。正数换算成二进制后最高位为0,负数的二进制最高为为1。负数的进制表示法是其对应的整数取反 +1

System.out.println(5>>3); // 0  
System.out.println(-5>>3); // -1  
System.out.println(-5>>>3); // 536870911  

5换算成二进制:0000 0000 0000 0000 0000 0000 0000 0101

-5换算成二进制:1111 1111 1111 1111 1111 1111 1111 1011

 

5换算成二进制 0000 0000 0000 0000 0000 0000 0000 0101

5右移3位结果为 0000 0000 0000 0000 0000 0000 0000 0000 // 用0进行补位


-5换算成二进制 1111 1111 1111 1111 1111 1111 1111 1011

-5右移3位结果为 1111 1111 1111 1111 1111 1111 1111 1111 // 用1进行补位


-5无符号右移3位后结果为 0001 1111 1111 1111 1111 1111 1111 1111  // 用0进行补位


转换成二进制后发现,正数右移高位用0补,负数右移高位用1补,当负数使用无符号右移时用0进行补位。



4 位与 ( & )

System.out.println(5 & 3); // 1


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



5 位或 ( | )

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



6 位异或 ( ^ )

System.out.println(5 ^ 3);// 6
System.out.println(5 ^ 3 ^ 3);// 5。这是异或的重要特性。a连续2次异或b还会还原为a,可以用于加密

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



7 位非 ( ~ )

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,反之亦然。


原贴地址:http://blog.csdn.net/xiaochunyong/article/details/7748713


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值