请教java移位运算问题:当移动位数是负数是怎么计算?不胜感激!!!

kcsrikei 2013-01-12 04:57:22
问题描述:

在java的源代码中,java.lang.Integer.java中循环左移的实现如下所示:

public static int rotateLeft(int i, int distance) {
return (i << distance) | (i >>> -distance);
}

问题:
请教一下:移动运算的位数是负数是如何计算的?!谢了!!
...全文
623 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhangqiang423 2014-05-19
  • 打赏
  • 举报
回复
i<<-1和i<<31 的结果一样 1 “-1”表示成补码是1111 ....11 1111 ,31是 0000 ...0011 1111,,他们的后六位是一样的。 2 Interger的移位运算只注意后6位,看注释 Note also that rotation by any multiple of 32 is a no-op, so all but the last five bits of the rotation distance can be ignored, even if the distance is negative: 总结:将负数写为补码,这个数的低6位便是其真正移位的数字。
龙四 2013-01-12
  • 打赏
  • 举报
回复

62,634

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧