Java中移位操作符的运算规则

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第三章中的一段话:  
   
    移位运算符面向的运算对象也是

<nobr id="key2" style="border-bottom: 1px dotted rgb(102, 0, 255); text-decoration: underline; color: rgb(102, 0, 255); background-color: transparent;" οnclick="return kwC();" target="_blank" οncοntextmenu="return false;" οnmοuseοver="kwE(event,2, this);" οnmοuseοut="kwL(event, this);" οnmοusemοve="kwM(2);">二进制</nobr>的“位”。 可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。 “有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。“有符号”右移位运算符<nobr id="key0" style="border-bottom: 1px dotted rgb(102, 0, 255); text-decoration: underline; color: rgb(102, 0, 255); background-color: transparent;" οnclick="return kwC();" target="_blank" οncοntextmenu="return false;" οnmοuseοver="kwE(event,0, this);" οnmοuseοut="kwL(event, this);" οnmοusemοve="kwM(0);">使用</nobr>了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0。这一运算符是C或C++没有的。  
    若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的<nobr id="key4" style="border-bottom: 1px dotted rgb(102, 0, 255); text-decoration: underline; color: rgb(102, 0, 255); background-color: transparent;" οnclick="return kwC();" target="_blank" οncοntextmenu="return false;" οnmοuseοver="kwE(event,4, this);" οnmοuseοut="kwL(event, this);" οnmοusemοve="kwM(4);">结果</nobr>也 是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或 short值进行右移位运算,得到的可能不是正确的结果(Java   1.0和Java   1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值