数字类型在JVM中的表示

数字类型在JVM中的表示

整数类型

整数在计算机用补码表示,JVM也不例外,要是理解补码,需要先了解解原码与反码

java语言规范中明确定义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)

浮点数类型

一样的Java虚拟机中定义了float与double两种浮点数类型,分别是32位与64位。

浮点数在JVM中的表示相对复杂,可以参考IEEE754规范,在IEEE754规范中,一个浮点数分别由三部分组成:符号位(sign)、指数位(exponent)和尾数位(fraction)。

以float类型为例,符号位占1位,指数位占8位,尾数位占23位
s eeee eeee fff ffff ffff ffff ffff ffff
sign:0为1,1为-1
exponent:eeee eeee
fraction:fff ffff ffff ffff ffff ffff

浮点数可以这样表示:value=sineexponentfraction

value=sign*(e2^0 +e2^(-1)+… …+e*2^(-23)) * 2^(exponent-129)

之前提到尾数位占23位,但是根据表达式看到的-23~0应是24位,这是为什么?

因为在取尾数位时,要在最前面添加一个数,细心的人也可以发现我fraction的二进制格式表示有点奇怪,本来应该是这样写的:ffff ffff ffff ffff ffff fff。
那应该加什么值?
这也很简单,根据指数位加值:
指数位中存在1:   1fff ffff ffff ffff ffff ffff
指数位中不存在1:0fff ffff ffff ffff ffff ffff

float中的特殊数字

意义
正无穷0 11111111 0000000000000000000000
负无穷1 11111111 0000000000000000000000
NaN0 11111111 1000000000000000000000
最大浮点数(3.4028235E38)0 11111110 11111111111111111111111
最小规范化正浮点数(1.17549435E-38)0 00000001 0000000000000000000000
最小正浮点数(1.4E-450 00000000 0000000000000000000001
00 00000000 0000000000000000000000
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值