Ricky Hao

C float在内存中的储存方法

众所周知,int类型的数据在内存中以32位储存,且第一位为符号位,实际储存为31位二进制,非常的好算。
但是,对于float类型来说,因为有小数部分,所以和int类型的储存方法是有点区别的。
一个浮点数由两部分组成:底数m指数e(均为二进制表示)。
《C float在内存中的储存方法》

首先,float储存时,第一位依旧为符号位。

但是,从第二位到第九位为指数位

以8-bit形式储存,储存范围为0~255。但是,因为指数有负数,所以规定最终取值为**原数值-127**。即,`129-127=2` ,二次幂。

然后,剩下的23-bit为底数部分的值。
其实,应该用24-bit来表示底数的取值,但是,因为无论什么数,第一位均为1因为是二进制储存的,所以除了0以外,其余的数转换为二进制的时候,第一位均为1)。因此,我们可以省略掉第一位,即用23-bit就能够储存24-bit的内容

那么,我们就先来看一个例子:

二进制    11000001    01001000    00000000    00000000
分割之后  1    10000010    10010000000000000000000
第一组    1            表示负数
第二组    10000010     十进制数据为130,因此,表示的幂次为 130-127=3 。
第三组    10010000000000000000000
先添加第一位的1,为:
         11001000 00000000 00000000

然后,开始运算。
第一步,我们要先确定小数点的位置。这时候,幂次就可以用得上了。
幂n>=0时,小数点右移n位。若**n12
对于小数部分,小数的转换方法为
《C float在内存中的储存方法》

所以,这里的小数部分为0.5。

那么,最终我们得到的浮点数就是12.5

点赞

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据