为什么四个字节的浮点数比八个字节的整数表示的范围广

为什么四个字节的浮点数比八个字节的整数表示的范围广,最主要的原因是因为两者在计算机中的存储结构不同,整数类型在计算机底层采用补码方式存储,除去首位的符号位,用0和1表示数字的正负,剩余的位数即表示数值的范围,也就是位数越多,范围越大,long在内存中占用8个字节共64位,符号位占一位,数值范围是负的2的63次方到正的2的63次方-1。float的存储结构则是4个字节32位,其中又分为符号位、指数域和小数域。符号位用来表示数字的正负,

主要的原因是因为浮点类型和整数类型的存储结构不相同,整数类型在计算机底层采用补码方式存储,除去首位的符号位,剩余的位数即表示数值的范围,也就是位数越多,范围越大,比如long在内存中占用8个字节共64位,符号位占一位,取值范围是-2^63--2^63-1。那么对于单精度浮点数float是采用这样的结构存储的,当然了double的结构也是这样,只不过double是8个字节(32位)的,下面依次介绍符号位、指数域和小数域的用处。符号位(1位):用来存储正负符号的,0表示正数、1表示负数,指数域(8位)来确定数的范围,约为-127到128,小数域(23位)来确定小数的精度,则float的取值范围约为-2^128--2^128

这样计算出的浮点数能够表示的范围会比长整型long表示范围大。
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值