当前位置:网站首页>为什么四个字节的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值,不会出现 编译出错。
边栏推荐
猜你喜欢
随机推荐
Spark的概念、特点、应用场景
华为Vlan创建及原理简单说明
DOM —— 事件类型
虚拟机使用的是此版本 VMware Workstation 不支持的硬件版本。模块“Upgrade”启动失败。未能启动虚拟机。
LAMP环境 源码编译安装(Apache 2.4.52 +mysql 8.0.28+php 8.1.3)
DOM - Event Object
FIR滤波器设计之窗函数法
假的服务器日志(给history内容增加ip、用户等内容)
小知识系列:Fork之后如何与原仓库分支同步
Scala的模式匹配与样例类
【故障诊断】基于PSO_VMD_MCKD方法的风机轴承微弱故障诊断
makefile——rule概览
lammps学习(二)联合原子模型聚乙烯拉伸
LAMP 环境搭建 yum源安装方式 (Apache 2.4.6 +mysql 8.0.28+php 8.1.3)
nodejs 的下载安装与环境配置
CSV file with the data read and write 】 【 XLS/XLSX file
GC垃圾回收ZGC
CPU缓存一致性协议MESI
【无标题】
ssm整合