先看位移运算

初识:
<<(左移)、>>(带符号右移)和>>>(无符号右移) (符号: 最高位 0 正数,1负数)。注意当刚好为数据长度的整数倍时,即32、64······,数据保持原来不变;其他情况下移动除以 32 余数的长度。

<<:例如 5<<1 -> 二进制为 0101 整体左移一位,缺的以0补足,变成 101 0 = 10 相当于 5 * 2 = 10。
>>:例如 10>>1 ->二进制为 1010 整体右移一位,正数高位为0,变成 0101 相当于 10 / 2 = 5。

例如-5 >>1 -> -3 ,具体怎么来的下面详细介绍

计算机用补码来表示数字,正数的补码等于他的原码 。负数的补码等于他的原码自低位向高位,尾数的第一个‘1’及其右边的‘0’保持不变,左边的各位按位取反,符号位不变。

例如 :

-5 的原码为

10000000 00000000 00000000 00000101

那么 -5 的补码为(注意右边出现的第一个一)

11111111 11111111 11111111 11111011

现在再来右移

111111111 11111111 11111111 1111101

那么它的原码为

10…11 =-3

同理,可以自行测试

System.out.println(Integer.toBinaryString(Integer.MAX_VALUE));//01111111111111111111111111111111 
System.out.println(Integer.toBinaryString(Integer.MAX_VALUE<<1));//11111111111111111111111111111110
System.out.println(Integer.MAX_VALUE<<1);//-2 11111111111111111111111111111110 的原码 10......010 = -2

>>>:无符号右移

最高位为0,那么上面-5>>>1就变成

01111111111111111111111111111101 = 2147483645

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值