黑马程序员技术交流社区
标题:
位移运算问题!!!!
[打印本页]
作者:
毕影彬
时间:
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