Double类型与Float类型,二者谁的取值范围更大?

关于取值范围

Double类型表示双精度浮点型,在内存中占8个字节,一个字节占8个比特位。8个字节一共得是64个比特位。其中从左往右数第一个是符号位(符号位表示该浮点数的正负,1代表-,0代表+),占一个比特位。再往后数11个比特位表示的是指数位(阶码)。而后面的52个比特位表示的是有效数字。 

Float 类型表示单精度浮点数,在内存中占4个字节。4个字节是32个比特位。其中从左往右数第一个是符号位,占一个比特位。再往后数8个比特位表示的是指数位(阶码)。而后面的23个比特位表示的是有效数字。

 需要注意的是:指数位E(x)也有正负值,即指数区的第一位就表示正负,1代表-,0代表+。由于指数范围的大小不受正负号的影响,因此真正决定指数的范围大小的是去除决定指数正负的那一比特位后的7个比特位而不是全部的8个比特位。Double同理,指数就是10,而不是11。

Float的指数范围 E(x)为-2^7~2^7-1,而double的指数范围为E(x)-2^10~2^10-1

从中可以得出,指数位决定了浮点数的大小范围,因此double类型的取值范围比float类型的取值范围更大。

关于精度问题

对于 Double 型浮点数,尾数部分52位,换算成十进制就是2^52=4503599627370496,所以十进制精度有15~16位。同理,Float类型的尾数部分换算成十进制就是2^23=8388608,所以十进制精度只有6~7位.

浮点数的精度是由尾数的位数来决定的,尾数部分的位数越多,能够表示的有效数字越多,精度就会越高。

float和double存储数据的时候都是存储的近似值。为什么?
 因为现实世界中有这种无线循环的数据,例如:3.3333333333333....数据实际上是无限循环,但是计算机的内存有限,用一个有限的资源 表示无限的数据,只能存储近似值。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值