黑马程序员技术交流社区

标题: 位移运算问题!!!! [打印本页]

作者: 毕影彬    时间: 2012-10-21 17:58
标题: 位移运算问题!!!!
本帖最后由 毕影彬 于 2012-10-22 17:48 编辑

system.out.println(-8>>>2),输出1073741822。求解释。谢谢。

作者: 马磊    时间: 2012-10-21 18:11
-8  的二进制为11111111111111111111111111111000。
无符号右移就是不管第一位为1或0都在前面补0,所以上面的二进制就变成了00111111111111111111111111111110,这个就是1073741822 的二进制
作者: 梁枝武    时间: 2012-10-21 18:18
-8的二进制表示为11111111111111111111111111111000
将其右移2位变为00111111111111111111111111111110 十进制表示为1073741822
作者: 黑马李超    时间: 2012-10-21 18:18
马磊 发表于 2012-10-21 18:11
-8  的二进制为11111111111111111111111111111000。
无符号右移就是不管第一位为1或0都在前面补0,所以上面 ...

正解。。。。。。。。
作者: 给生活加点料    时间: 2012-10-21 19:31
首先负数的二进制是正数的二进制取反加1.    8的二进制简写是0000-1000,补全的话
二进制表示为11111111 11111111 11111111 11111000
将其右移2位变为00111111111111111111111111111110
这么大的数我目测是看不出来了。不过应该就是你说的那个结果,你可以用计算器验证一下。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2