参考:《Java语言程序设计》第二章
《Java核心技术 卷I:基础知识》第三章
#####################################################################333
在Java中,有关位的运算有两类:位运算符运算(Bitwise)和移位运算(Shift)。
位运算符只能用于整型数据,包括byte,short,int,long 和 char类型,不能用于浮点型数据
在Java语言中,整数用补码表示
在补码表示中,最高位为符号位,正数的符号位为0,负数的符号位为1。若一个数为正数,补码与原码相同;若一个数为负数,补码为原码的反码加1
例如,+42的补码为:00000000 00000000 00000000 00101010
-42的补码为:11111111 11111111 11111111 110101110
#########################################################################3
位逻辑运算符包括按位取反(~),按位与(&),按位或(|),按位异或(^)4种
位逻辑运算是对一个整数的二进制位进行运算。设A,B表示操作数中的一位,位逻辑运算的运算规则如下:
位逻辑运算的运算规则
A
B
~A
A&B
A|B
A^B
0
0
1
0
0
0
0
1
1
0
1
1
1
0
0
0
1
1
1
1
0
1
1
0
位逻辑运算是对运算数的每一位按位取反
如果两个操作数宽度(位数)不同,在进行按位运算时要进行扩展。例如一个int型数据与一个long型数据按位运算,现将int型数据扩展到64位,若为正,高位用0扩展,若为负,高位用1扩展,然后在进行位运算。
#####################################################333333
移位运算符
Java语言提供3个移位运算符:左移运算符(<>)和无符号右移运算符(>>>)。
左移运算符(<
+42 << 6 结果为:2688
00000000 00000000 00000000 00101010 << 6 结果为 00000000 00000000 00001010 10000000
-42 << 6 结果为:-2688
10000000 00000000 00000000 00101010 << 6 结果为 0000000 00000000 00001010 10000000
相当于[-]42乘以2的6次方
右移运算符(>>)用来将一个整数的二进制位序列右移若干位。移出的低位丢弃,若为正数,移入的高位添0,若为负数,移入的高位添1:
例如,-192的二进制序列为
11111111 11111111 11111111 01000000
若执行-192 >> 3,结果为-24:
11111111 11111111 11111111 11101000
无符号右移运算符(>>>)也是将一个整数的二进制位右移若干位。它与右移运算符的区别是,不论正数还是负数,左边一律移入0:
若执行-192 >>> 3,结果为536 870 888:
00011111 11111111 11111111 11101000
移位操作是连同符号位一同操作的