当前位置:网站首页>为什么四个字节的float表示的范围比八个字节的long要广?
为什么四个字节的float表示的范围比八个字节的long要广?
2022-08-02 14:19:00 【来日方长。。。。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值,不会出现 编译出错。
边栏推荐
猜你喜欢
随机推荐
JMM&synchronized&volatile详解
web渗透之sql注入
appium 报错:AttributeError:
ssm整合
超简单了解三次握手与四次挥手
【面经】被虐了之后,我翻烂了equals源码,总结如下
个人成长系列:好问题清单
webrtc 有关 SDP 部分的解析流程分析
【web渗透】文件包含漏洞入门级超详细讲解
DOM - Event Delegate
静态方法的缺失
MYSQL5.7详细安装步骤
(三)文件操作之一——文件IO
详解C语言中的位操作运算符可以怎么用?
2021年华为杯数学建模竞赛E题——信号干扰下的超宽带(UWB)精确定位问题
华为单臂路由配置,实现不同vlan之间的通信
加点字符就能让qq昵称很酷的神奇代码?
数据库性能优化的误区!
APP版本更新通知流程测试要点
mongodb连接本地服务失败的问题








