java中int数据存储格式

byte,short,int在Java中的存储方式:
因为byte,short都可以用int来表示,所以我只讨论了int的存储方式,
一般在Java中的整形存储方式:
int基本类型的表示范围:-231---231-1,而在C语言中也是如此,但C
语言给我们更多的选择,那就是我们可以显示的定义无符号的整形(如unsigned int a),
它就可以表示更大的整数,它的范围为:0-232
那么在Java中整形到底是怎样存储的呢?
在Java中,所有的基本类型都硬性规定了基本类型所能够占用的字节数,
byte占用8个字节,short占用16个字节,int占用32个字节,下面我们来看一下它内部的布局,也就是
在计算机中存储的布局

3130-0
符号位可以为1或0,1代表为负整数,0代表为正整数第30位到0位,为真正的存储数据的地方,因为总共有31位,加上0,所以他可以表示的范围:-231---231-1


上面就是Java内部数据的存储布局。

 

正数的存储为第31预设为零,其他按正整数转换为二进制方法对其他的31位进行填充。比如1234,它的二进制编码为10011010010,说明在32位中只使用的11位,前面的21位没有列举出来,实际的存储数据应该是:

00000000000000000000010011010010.


我们来看一看负数的存储方式,在Java中负数的存储并不像我们想象中的一样,31位为1,其他和正整数的存储一样,其实不然。
正整数可以表示的最大值的二进制编码为:

011111111111111111111111111111111,即2147483647,而在这里就是我们正数与负数的分界线。

 

111111111111111111111111111111111表示-1,而-2是-1-1,所以-2为111111111111111111111111111111110,依次继续就可以得到我们所需要的负数了,这就是计算机中负整数的存储方式

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值