浮点类型在内存中的存储方式

通过一个例子来理解怎么将一个浮点数转换为内存中的存储格式。比如浮点数 5.625

1. 5.625将整数部分和小数部分用二进制表示,就是101.101。为什么呢?

1)首先整数部分5的二进制为101;
2)其次是小数部分0.625转换为.101,可以把小数部分乘以2,取整数部分作为二进制的一位,剩余小数继续乘以2,直至不存在剩余小数为止(这里可能永远都有小数,但是位数存储有限,所以最后会截取,保留的是一个近似值,这也是我们经常类型转换时出现精度丢失的原因)。具体如下:
0.625 * 2 = 1.25 ==> 1
0.25 * 2 = 0.5 ==> 0
0.5 * 2 = 1.0 ==> 1

所以最后拼接整数和小数的二进制就是101.101。

2.101.101 转换为 (-1)^0 * 1.01101 * 2^2

注:不同系统64位的存储模型可能不同(待验证)


单精度存储模型

双精度存储模型

根据国际标准IEEE(电气和电子工程协会)规定,任何一个浮点数(F)可以通过图中的S、E、M表示为下面的形式:

  1. F=(-1)^S * M * 2^E
  2. (-1)^S表示符号位,当S=0时,为正;当S=1时,为负
  3. M表示有效数字,M>=1且M<2
  4. 2^E表示指数位

通过以上标准最终得到101.101 = (-1)^0 * 1.01101 * 2^2。

3.(-1)^0 * 1.01101 * 2^2转换为内存中的存储格式

在上面的标准中,S只可能为0或者1,所以只需用一个bit位即可保存。
对于M:
前面说过,M>=1且M<2,也就是M可以表示为1.xxxxxxxxxxx的形式,其中xxxxxxxxxxx即为小数部分。
所以在存储M的时候,只需要存储后面的小数部分就可以了,比如1.011,在存储的时候只存储011。等到读取的时候,只需在前面加上1即可。并且这样做,还可以节省一位有效数字。假如把1保存进去,则小数点后面只能保存22位有效数字,如果不把1保存进去,皆可以保存23位有效数字。
但对于E而言,情况比较复杂:
首先,E是一个无符号整数(unsigned int)
这表示,对于单精度浮点数而言,E的取值范围为0到255;对于双精度浮点数而言,E的取值范围为0到2047
但是,在科学计数法中,E是可以取负数的
IEEE 754规定:存入内存时,E的真实值必须加上一个中间数
对于单精度浮点数,中间数为127
对于双精度浮点数,中间数为1023
E可以分为三种情况:
1.E不全为0或不全为1
这种情况是比较常规的,按照上面的规则就可以了
2.E全为0
此时,浮点数的指数E等于1-127(或1-1023)即为真实值
有效数字M不再加上第一位的1,而是还原成0.xxxxxxxx的形式。
此时是一个接近于0的很小的数字
3.E全为1
此时,如果有效数字M全为0,表示+无穷或-无穷(正负取决于S)。

1)S部分:(-1)^0转换为 0;
2)E部分:2^2中指数为2,根据上面对于E的规则,可转换为2+127 = 129,二进制表示为10000001
3)M部分:1.01101根据规则,省略整数部分的1,保留01101,然后转换为23bit的二进制:01101000000000000000000
最终组成浮点数内存中的存储格式:0 10000001 01101000000000000000000。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,635评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,543评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,083评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,640评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,640评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,262评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,833评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,736评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,280评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,369评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,503评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,185评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,870评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,340评论 0 24
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,460评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,909评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,512评论 2 359

推荐阅读更多精彩内容