Java中左移和右移问题图文详解
短信预约 -IT技能 免费直播动态提醒
1 原码、反码、补码
原码:将十进制转化为二进制即原码;
反码:正数的反码与原码相同,负数的反码(除却最高位的符号位不变)与原码相反;
补码:正数的补码与原码相同,负数的补码(除却最高位的符号位不变)与原码的取反加一。
举例:5 和 -5
5:原码:0 0000000 00000000 00000000 00000101反码:0 0000000 00000000 00000000 00000101补码:0 0000000 00000000 00000000 00000101-5:原码:1 00000000 00000000 00000000 00000101反码:1 1111111 11111111 11111111 11111010补码:1 1111111 11111111 11111111 11111011
2 位移操作
我们需要知道将一个数字,在计算机中进行移动多少位,例如8<<1代表将8转化为二进制在计算机中左移1位,低位补零;
<<:左移:低位补0
>>:有符号右移:正数高位补0,负数高位补1
>>>:无符号右移,高位补零
为什么没有无符号左移呢?因为左移的情况下只存在补零的情况。
举例 :5 和 -5
5<<1原码:0 0000000 00000000 00000000 00000101左移1位:0 0000000 00000000 00000000 00001010即:10-5<<1原码:1 00000000 00000000 00000000 00000101补码:1 1111111 11111111 11111111 11111011左移1位:1 1111111 11111111 11111111 11110110取其补码:1 0000000 00000000 00000000 00001010即:-105>>1原码:0 0000000 00000000 00000000 00000101右移1位:0 0000000 00000000 00000000 00000010即:2-5>>1原码:1 00000000 00000000 00000000 00000101补码:1 1111111 11111111 11111111 11111011右移1位:1 1111111 11111111 11111111 11111101取其补码:1 0000000 00000000 00000000 00000011即:-35>>>1:与5>>1一样,都是高位补0原码:0 0000000 00000000 00000000 00000101右移1位:0 0000000 00000000 00000000 00000010即:2-5>>>1原码:1 00000000 00000000 00000000 00000101补码:1 1111111 11111111 11111111 11111011右移1位:0 1111111 11111111 11111111 11111101即:2147483645
代码运行截图
总结:
位移操作很简单,使用补码移动,补齐空缺位就行,除了>>:补与最高位一致的;其他移动哪缺哪补零。
在java中无论截图中的a定义成 byte,short,int哪一种类型,它默认都是使用int类型(4字节32位),你使用long(8字节64位)
3 补充操作符
~(按位非):
逐位取反
|(按位或):
一真为真1|0=1,0|0=0,1|1=1,0|1=1
&(按位与):
两真为真1|0=0,0|0=0,1&1=1;0&1=0
^(按位异或):
相异为真1^1=01^0=10^1=10^0=0.
总结
到此这篇关于Java中左移和右移问题的文章就介绍到这了,更多相关Java左移和右移内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341