整数在JVM中的表示

こ雲淡風輕ζ 提交于 2020-01-11 23:15:20

java语言规范中明确定义了byte、short、int、long 分别为8位、16位、32位、64位的有符号整数。

原码:符号位+数字的二进制位表示,以int为例,第一位为符号位,剩下31位是二进制值,所以int最大值为2的31次-1,最小值为2的31次。

8的原码:0000 0000 0000 0000 0000 0000 0000 1000
-8的原码:1000 0000 0000 0000 0000 0000 0000 1000

反码:原码中的符号位不变,二进制值全部取反。

8的反码:0111 1111 1111 1111 1111 1111 1111 0111
-8的反码:1111 1111 1111 1111 1111 1111 1111 0111

补码:正数的补码为原码本身,负数的补码是反码+1(补码不存在正负,也就是说补码没有符号位)

8的补码:0000 0000 0000 0000 0000 0000 0000 1000
-8的补码:1111 1111 1111 1111 1111 1111 1111 1000

注意事项:因为举例举得不是很好所以,特别声明

(这里-8的补码最后四位1000为8只是巧合,可能会让人产生误解,出现这种情况,认为-8的补码:
1111 1111 1111 1111 1111 1111 1111 1110
那么:-1的补码就为:
1111 1111 1111 1111 1111 1111 1111 0001
其实并不是,通过计算验证就会发现-1的补码应为:
1111 1111 1111 1111 1111 1111 1111 1111)

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!