IEEE754标准的浮点数存储格式
操作系统 : CentOS7.3.1611_x64
gcc版本 :4.8.5
基本存储格式(从高到低) : Sign + Exponent + Fraction
Sign : 符号位
Exponent : 阶码
Fraction : 有效数字
32位浮点数存储格式解析
Sign : 1 bit(第31个bit)
Exponent :8 bits (第 30 至 23 共 8 个bits)
Fraction :23 bits (第 22 至 0 共 23 个bits)
32位非0浮点数的真值为(python语法) :
(-1) **Sign * 2 **(Exponent-127) * (1 + Fraction)
示例如下:
a = 12.5
1、求解符号位
a大于0,则 Sign 为 0 ,用二进制表示为: 0
2、求解阶码
a表示为二进制为: 1100.0
小数点需要向左移动3位,则 Exponent 为 130 (127 + 3),用二进制表示为: 10000010
3、求解有效数字
有效数字需要去掉最高位隐含的1,则有效数字的整数部分为 : 100
将十进制的小数转换为二进制的小数的方法为将小数*2,取整数部分,则小数部分为: 1
后面补0,则a的二进制可表示为: 01000001010010000000000000000000
即 : 0100 0001 0100 1000 0000 0000 0000 0000
用16进制表示 : 0x41480000
4、还原真值
Sign = bin() = Exponent = bin() = Fraction = bin(0.1001) = ** (-) + ** (-) = 0.5625
真值:
(-) ** * **(-) * ( + 0.5625) = 12.5
32位浮点数二进制存储解析代码(c++):
https://github.com/mike-zhang/cppExamples/blob/master/dataTypeOpt/IEEE754Relate/floatTest1.cpp
运行效果:
[root@localhost floatTest1]# ./floatToBin1
sizeof(float) :
sizeof(int) :
a = 12.500000
showFloat : 0x
UFP : ,,
b : 0x41480000
showIEEE754 a = 12.500000
showIEEE754 varTmp = 0x00c00000
showIEEE754 c = 0x00400000
showIEEE754 i = , a1 = 1.000000 , showIEEE754 c = , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x41000000
showIEEE754 : 0x41480000
[root@localhost floatTest1]#
64位浮点数存储格式解析
Sign : 1 bit(第31个bit)
Exponent :11 bits (第 62 至 52 共 11 个bits)
Fraction :52 bits (第 51 至 0 共 52 个bits)
64位非0浮点数的真值为(python语法) :
(-) **Sign * **(Exponent-) * ( + Fraction)
示例如下:
a = 12.5
1、求解符号位
a大于0,则 Sign 为 0 ,用二进制表示为: 0
2、求解阶码
a表示为二进制为: 1100.0
小数点需要向左移动3位,则 Exponent 为 1026 (1023 + 3),用二进制表示为: 10000000010
3、求解有效数字
有效数字需要去掉最高位隐含的1,则有效数字的整数部分为 : 100
将十进制的小数转换为二进制的小数的方法为将小数*2,取整数部分,则小数部分为: 1
后面补0,则a的二进制可表示为:
0100000000101001000000000000000000000000000000000000000000000000
即 : 0100 0000 0010 1001 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000
用16进制表示 : 0x4029000000000000
4、还原真值
Sign = bin() =
Exponent = bin() =
Fraction = bin(0.1001) = ** (-) + ** (-) = 0.5625
真值:
(-) ** * **(-) * ( + 0.5625) = 12.5
64位浮点数二进制存储解析代码(c++):
https://github.com/mike-zhang/cppExamples/blob/master/dataTypeOpt/IEEE754Relate/doubleTest1.cpp
运行效果:
[root@localhost t1]# ./doubleToBin1
sizeof(double) :
sizeof(long) :
a = 12.500000
showDouble : 0x
UFP : ,,
b : 0x0
showIEEE754 a = 12.500000
showIEEE754 logLen =
showIEEE754 c = (0x4020000000000000)
showIEEE754 b = 0x4020000000000000
showIEEE754 varTmp = 0x8000000000000
showIEEE754 c = 0x8000000000000
showIEEE754 i = , a1 = 1.000000 , showIEEE754 c = , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 i = , a1 = 0.000000 , showIEEE754 b = 0x4020000000000000
showIEEE754 : 0x4029000000000000
[root@localhost t1]#
好,就这些了,希望对你有帮助。
本文github地址:
https://github.com/mike-zhang/mikeBlogEssays/blob/master/2018/20180117_IEEE754标准的浮点数存储格式.rst
欢迎补充
IEEE754标准的浮点数存储格式的更多相关文章
- 将四个BYTE数值转换成IEEE754标准的浮点数(两种方法:用Addr函数取字节数字的首地址,或者用Absolute关键字)
在工作中,经常使用到IEEE754格式的数据.IEEE754格式的数据占四个字节,好像Motorola格式和Intel格式的还不一样. 由于工作中很少和他打交道(使用的软件内部已经处理),就没太在意. ...
- C#中浮点数依IEEE-754标准转二进制串 (MODBUS 浮点数转换)
因工作需要,把再串口通信中浮点数与字节流的数据转换函数放在这,转发的,谢谢原作者. 今天花了一天的时间搜罗资料,为了解决一个串口编程的进制转化问题.因为串口传送的浮点数据格式与IEEE-754标准(3 ...
- 第二章 运算方法与运算器(浮点数的加减法,IEEE754标准32/64浮点规格化数)
这一章,主要介绍了好多种计算方法.下面,写一点自己对于有些计算(手写计算过程)的见解. 1.原码.反码.补码 原码:相信大家都会写,符号位在前二进制数值在后,凑够位数即可. 反码:原码符号位不变,其他 ...
- 十进制浮点数转换成IEEE754标准的32浮点数的二进制格式
参考: http://jimmygod.blog.163.com/blog/static/43511339200792605627411/ http://blog.csdn.net/archersab ...
- IEEE754标准浮点数表示与舍入
原文地址:https://blog.fanscore.cn/p/26/ 友情提示:本文排版不太好,但内容简单,请耐心观看,总会搞懂的. 1. 定点数 对于一个无符号二进制小数,例如101.111,如果 ...
- IEEE754标准浮点格式
两种基本浮点格式:单精度和双精度.IEEE单精度格式具有24位有效数字,并总共占用32 位.IEEE双精度格式具有53位有效数字精度,并总共占用64位 两种扩展浮点格式:单精度扩展和双精度扩展.此标准 ...
- IEEE754标准
以下计算按规格化规定: S:符号位 M:分数值 E:指数偏移值 单精度浮点数(32bit): NUM_single = (-1)^S * 1.M * 2^(E-127) 双精度浮点数(64b ...
- 【转载】JS Number类型数字位数及IEEE754标准
JS的基础类型Number,遵循 IEEE 754 规范,采用双精度存储(double precision),占用 64 bit.如图 意义 1位用来表示符号位 11位用来表示指数 52位表示尾数 浮 ...
- JS Number类型数字位数及IEEE754标准
JS的基础类型Number,遵循 IEEE 754 规范,采用双精度存储(double precision),占用 64 bit.如图 意义 1位用来表示符号位 11位用来表示指数 52位表示尾数 浮 ...
随机推荐
- IDEA添加源码包
1.在项目中选中左上角的File--->Project Structure 2.选择需要添加的源码包 3.源码已经加入
- Codeforces 1130D1 Toy Train (Simplified) (思维)【贪心】
<题目链接> 题目大意: 有一个的环形火车站,其中有$[1,n] n$个站台,站台上能够放糖果,火车只能朝一个方向移动,如果火车在站台$i$,那么下一秒就会在$i+1$站(如果$i=n$, ...
- HDU 3416 Marriage Match IV 【最短路】(记录路径)+【最大流】
<题目链接> 题目大意: 给你一张图,问你其中没有边重合的最短路径有多少条. 解题分析: 建图的时候记得存一下链式后向边,方便寻找最短路径,然后用Dijkstra或者SPFA跑一遍最短路, ...
- Django之认证系统
Django之认证系统 cookie和session 1.cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞 ...
- CSS基础以及属性
一.CSS 偷个懒,啥是CSS我就不介绍啦 二.CSS语法 CSS语法:选择符{属性:属性值:属性:属性值:}选择符表示要定义样式的对象,可以是元素本身,也可以是一类元素或者制定名称的元素.属性:属性 ...
- MD5_Util工具类代码
package com.yby.mall.utils; import java.math.BigInteger; import java.security.MessageDigest; public ...
- staff
staff英 [stɑ:f] 四大服. 美 [stæf] n.参谋;全体职员;管理人员;权杖adj.职员的;行政工作的;参谋的;作为正式工作人员的v.在…工作;为…配备职员;任职于第三人称单数: st ...
- BZOJ.1115.[POI2009]石子游戏Kam(阶梯博弈)
BZOJ 洛谷 \(Description\) 有\(n\)堆石子.除了第一堆外,每堆石子个数都不少于前一堆的石子个数.两人轮流操作,每次可以从一堆石子中拿掉任意多的石子,但要保证操作后仍然满足初始时 ...
- NOIP复习篇
NOIP复习篇---枚举 --------------------------------------------------------------------------------------- ...
- 冲刺NOIP复习,算法知识点总结
前言 离NOIP还有一个星期,匆忙的把整理的算法补充完善,看着当时的整理觉得那时还年少.第二页贴了几张从贴吧里找来的图片,看着就很热血的.当年来学这个竞赛就是为了兴趣,感受计算机之美的. ...