浮点数小结

浮点数是计算机内部储存数值的一种方法。
计算机内部存储数值如果按照一般存储的方法,以32位为例,则最大值只能表示
1111…1111(32个)=232=4,294,967,296
而且这里没有考虑符号位和小数位。
如果用一位数表示符号位,并且再用一部分数表示小数位,那么32位计算机一次能表示的数值范围就会变得很小了。为了能够用固定的位数表示足够大范围的数据,就引入了浮点数。

浮点数分为单精度浮点数(32位)和双精度浮点数(64位)
单精度浮点数的表示范围为 3.4E-38~3.4E+38
双精度浮点数的表示范围为 1.7E-308~1.7E+308
可见使用浮点数表示数的范围比定点数大了许多。

浮点数的表示方法

在这里插入图片描述

浮点数如图所示,以32位为列,用一位来表示符号位S,一部分位数表示指数位E,另一部分表示尾数位M。其表示方法类似于科学计数法,无论任何数都可以近似化成S(-1)×2E×1.xxx的形式(因为在2进制的体系中用2为基数,那么底数增大或减小都相当于位的左移右移)

符号位:表示数的正负,0表示正数,1表示负数。

指数位:在32位的系统中,用8位表示指数,那么8位的取值范围为0~255,其中间数为127,因为指数中可能有负数,所以为了能够表示负数,真实的基数需要减去固定值127。 (也可以空出一位专门表示基数位的符号位,其占位和表示范围不变)

尾数位:即1.xxx,表示数的具体的值样。

规格化

规格化就是指将浮点数按照一定规则表示。由于浮点数M总是能写成M=(-1)s(1.xxx)2E的形式。(通过小数点左移右移来完成)
故,我们称尾数位为1.xxxx形式时,该浮点数就是规格化形式。
这样尾数的第一位总是为1,这样我们就可以省略第一位1,而只在尾数中保留小数点后的数值,来节省一位有效位来存储信息。(我在网上还见过规格化尾数为0.xxx的形式,但其实不论哪个道理都是一样的)

浮点数举例

以(+56)10在转化成浮点数为列:
(+56)10=111000(2)=1.11× 25
尾数位:11000(省略最高位1)
指数位:阶码(5)10=(101)2, 还需要加上(01111)即结果为(10100)2(基数位需加上一个中间数)
符号位:由于56为正数故符号位为0.
那么最终浮点数的结果为:
0 000010100 1100……0000

最后让我们欣赏下64位浮点数的表示方法:
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值