浮点数是计算机内部储存数值的一种方法。
计算机内部存储数值如果按照一般存储的方法,以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位浮点数的表示方法:
,