Java的4个位运算和3个移位运算

位运算:& 、|、^、~

1.&(按位与) :两位都为1,结果为1,否则为0;

例:2&3   ==>  转换为二进制 (计算机在运算的时候,都是以补码的方式运算的)

  2: 0000 0010

  3: 0000 0011

————————

         0000 0010     == >转换为十进制 == > 2

2.|(按位或):两位只要有一位为1,结果为1,否则为0;

例:2|3 ==>转换为二进制

  2: 0000 0010

  3: 0000 0011

————————

        0000 0011     == >转换为十进制 == > 3 

3.^(按位异或):两位一位为0,一位为1,结果为1,否则为0;

例:2^3 == >转换为二进制

  2: 0000 0010

  3: 0000 0011

————————

        0000 0001    == >转换为十进制 == >1

4.~(按位取反):0变1,1变0;

例:~2 == >转换为二进制

       2: 0000 0010

——————————

           1111 1101  (补码)     负数补码=反码(原码符号位不变,其他位取反)+1

           1111 1100  (反码)    == > 1000 0011 (原码) == >转换为十进制 == >-3

 

移位运算:>>、<<、>>>     (注意:没有<<<!!)

1.>>算术右移:符号位不变,低位溢出,符号位补溢出的高位;

例:int a = 1>>2;    

      0000 0001 == > (00)00 0000 == > 0;

2.<<算术左移:符号位不变,底位补0;

例: int a = 1<<2;

      0000 0001 == > 0000 01(00) == > 4;

3.>>>逻辑右移:无符号右移,低位溢出,高位补0;

例:int a = 3>>>2;

      0000 0011 == > (00)00 0000 == > 0;


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值