为什么四个字节的float表示的范围比八个字节的long要广?


float:4个字节
long:8个字节

因为整数与小数的底层存储有点不同。
相同点:它们都是用二进制存储的
不同点:小数先转成二进制,然后处理,然后存储。

long在内存中占用8个字节共64位,符号位占一位,数值范围是-2的63次方到正2的63次方-1。那么对于单精度浮点数float是采用这样的结构存储的,当然了double的结构也是这样,只不过double是8个字节(32位)的

                                                                        浮点类型存储结构

符号位:用来存储正负符号的,0表示正数,1表示负数

指数域:确定数的范围

小数域:确定小数的精度

浮点数的表示按照这个公式计算而来

 vlue=(-1)^符号位(S) * 小数域 (E)* 2^指数域(M)

 我们可以先用程序看一下结果

从这里看运行结果,可知float表示的范围比八个字节的long要大

故而在JAVA使用float时,使用long值赋值给float值,不会出现 编译出错。

  • 12
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值