int类型和float类型在内存中的存储形式

int类型

  • 在内存中占 4个字节,32位
  • 表数范围:-2147483648(-231)~2147483648(231-1)
    原因:0 代表 +0,-0 代表 -2^31,故负数比整数多一个。
  • 32位二进制的最高位为符号位,当符号位是 1 的时候表示一个负数
int b =0b11010100;
System.out.println(b);
int c =0b00000100;
System.out.println(c);

输出为
212
4
需注意的是:
计算机以补码存取数据
正数原码补码相同
负数的补码为该数的原码除符号位以外按位取反,然后在最后一位加 1
所以-2 表达形式如下

	int d = 0b11111111111111111111111111111110;
	System.out.println(d);

输出为
-2

float类型

Java的浮点类型有固定的表数范围和字段长度。

  • 在内存中占 4个字节,32位
  • 表数范围 -2128~ 2128 约等于-3.4E38~3.4E38
  • 第一位是符号位,接下来的8位表示指数,再接下来的23位表示底数
    需注意的是 指数可正可负,所以,IEEE规定,此处算出的次方必须减去127才是真正的指数。
    所以,float类型的指数可从-126到128。

根据国际标准IEEE754,任意一个二进制浮点数可以表示为下面的形式
V = (-1)s * M * 2e

  • (-1)s表示符号位 s=0时V为正数s=1时V为负数
  • M表示底数大于等于1,小于2
  • 2e表示指数

举个例子:
10.125的二进制为1010.001
再将1010.001的小数点左移,直到小数点前只剩一位。
变成1.010001*23 因为小数点左移了3位

此时 指数 e = 3+127(转出的时候会自动减去127) 所以e=130;
底数 因为小数点前必为1,所以IEEE规定只记录小数点后的就好。所以,此处的底数为:M = 010001;
符号位 正数 为零
综上所述,10.125在内存中的存储格式为:
0 10000010 0000000000000000010001;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值