心 空

  • Tools
Ricky Hao
  1. 首页
  2. C
  3. 正文

C float在内存中的储存方法

14 9 月, 2015 2092点热度 0人点赞 0条评论

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

首先,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
对于小数部分,小数的转换方法为
float_2.png

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

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

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: C
最后更新:14 9 月, 2015

Ricky

这个人很懒,什么都没留下

点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理。

COPYRIGHT © 2025 心 空. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang