爱笑的果子狸 2023-03-16 15:21 采纳率: 100%
浏览 33
已结题

java的<<和>>,算术左移和算术右移

刚学java没多久,希望大家帮我看看,我这个笔记对不对?

总结,在不溢出的情况下,整数的位运算情况如下(未验证):
1.算术左移n位相当于乘2^n

2.正整数的算术右移n位,相当于除以2^n,
m>>n 的结果和 m/2^n 的结果相同
如 -9>>2 的结果 和 -9/2^2 的结果都为2

3.负整数的算术右移n位,跟正整数不同
若 m除以2^n 的余数为0的时候,也相当于除以2^n,m>>n 的结果和 m/2^n 的结果相同
若 m除以2^n 的余数不为0的时候,m>>n 的结果应该 为 m/2^n - 1
如 -9>>2 的结果为-3 但是 -9/2^2 的结果为-2

  • 写回答

2条回答 默认 最新

  • threenewbee 2023-03-16 15:25
    关注

    基本正确,但是你可以简化记忆
    负数的表示形式是,最高位二进制1
    其余为补码,也就是绝对值取反+1
    所以你向左向右移动,再转换成十进制,就容易理解了。不要强行记忆。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 3月23日
  • 已采纳回答 3月16日
  • 创建了问题 3月16日