原码、反码、补码

原码第一位是符号位,表示正负,0是正,1是负,后面的表示数值

反码:正数和原码一样 ,负数的话,符号位不变,其他位置取反

补码:正数和原码一样 ,负数的话,就是反码+1

 

计算机的二进制是由补码来表示的,所以在计算左移右移时,需要将二进制转换为原码计算结果(二进制-1,然后取反)

Integer的最大值(Integer.MAX_VALUE)是2147483647,二进制是0111 1111 1111 1111,所以如下:

补码:0111 1111 1111 1111 ,左移1位后,1111 1111 1111 1110, 因为是补码,所以要转换为原码计算(二进制-1,然后取反),减一后: 1111 1111 1111 1101 ,然后取反:1000 0000 0000 0010 ,值为-2

左移n位,就是乘以2的n次方

右移n位,就是除以2的n次方

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值