`
dogstar
  • 浏览: 271778 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

java位操作

阅读更多
无符号右移位操作符“>>>”在将bit串右移位时,从bit串的最左边填充0,这和带符号右移位操作符“>>”不同。“>>”在将bit串右移位时,从bit串的最左边填充原来最左边的位。也就是说,bit串原来最左边的位是符号位,如果为1,则在带符号右移时最左边始终填充1;如果为0,则在带符号右移时最左边始终填充0。
  移位操作符的例子见下表。
操作	结果	说明
00110010 << 2	11001000	右边始终填充0
00110010 >> 2	00001100	结果一样
00110010 >>> 2	00001100
10110010 >> 2	11101100	结果不同
10110010 >>> 2	00101100


“按位与”操作符“&”对两个bit串按位进行逻辑与,“按位或”操作符“|”对两个bit串按位进行逻辑或,“按位异或”操作符“^”对两个bit串按位进行异或操作。运算规则如下表所示。

按位与	按位或	按位异或
0 & 0 = 0	0 | 0 = 0	0 ^ 0 = 0
0 & 1 = 0	0 | 1 = 1	0 ^ 1 = 1
1 & 0 = 0	1 | 0 = 1	1 ^ 0 = 1
1 & 1 = 1	1 | 1 = 1	1 ^ 1 = 0



---------------------华丽的分割线------------------------------------------


Java中的移位,如果是short,char,byte的话,都会转换成int的形式
再进行移位的。
试看:
1.)  byte a = 27;// 转换成int为 00000000000000000000000000011011
         byte b = -1;转换成int为  11111111111111111111111111111111

int g = a >> 1;// 有符号右移1位,左侧缺的位以符号位补齐,正数就是0,  "00000000000000000000000000001101" = 13
int f  = b>> 1; // 有符号右移1位,左侧缺的位以符号位补齐,负数就是1,   “11111111111111111111111111111111”=   -1

故此时打印出来,g=13,gf=-1。



g = a >>> 1;// 无符号右移1位,左侧缺的位以0补齐,  "00000000000000000000000000001101" = 13
f  = b>>> 1; // 无符号右移1位,左侧缺的位以0补齐,  “01111111111111111111111111111111”=   2147483647

故此时打印出来,g=13,gf=2147483647。

f  = b<< 1; // 无符号左移1位,右侧缺的位以0补齐,  “10000000000000000000000000000010“=   -2
故此时打印出来,f= -2

在Thinking   in   Java第三章中的一段话: 
  
    移位运算符面向的运算对象也是

二进制的“位”。 可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。 “有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。“有符号”右移位运算符使用了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0。这一运算符是C或C++没有的。 
    若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也 是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或 short值进行右移位运算,得到的可能不是正确的结果(Java   1.0和Java   1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。

分享到:
评论
2 楼 abruzzi 2008-12-24  
不错,比较喜欢这类底层的东西。

几乎所有的平台都有位操作的机器指令,这样编译后的class执行速度会更快
比如,一个数a,做a*2操作,需要下面的步骤
1.给变量a分配空间
2.执行a*2指令
3.将结果写回原地址
而a<<1,只需要执行一条指令即可,速度上会得到提升。
1 楼 f32647908 2008-11-13  
good!!

相关推荐

Global site tag (gtag.js) - Google Analytics