操作系统 : 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标准的浮点数存储格式的更多相关文章

  1. 将四个BYTE数值转换成IEEE754标准的浮点数(两种方法:用Addr函数取字节数字的首地址,或者用Absolute关键字)

    在工作中,经常使用到IEEE754格式的数据.IEEE754格式的数据占四个字节,好像Motorola格式和Intel格式的还不一样. 由于工作中很少和他打交道(使用的软件内部已经处理),就没太在意. ...

  2. C#中浮点数依IEEE-754标准转二进制串 (MODBUS 浮点数转换)

    因工作需要,把再串口通信中浮点数与字节流的数据转换函数放在这,转发的,谢谢原作者. 今天花了一天的时间搜罗资料,为了解决一个串口编程的进制转化问题.因为串口传送的浮点数据格式与IEEE-754标准(3 ...

  3. 第二章 运算方法与运算器(浮点数的加减法,IEEE754标准32/64浮点规格化数)

    这一章,主要介绍了好多种计算方法.下面,写一点自己对于有些计算(手写计算过程)的见解. 1.原码.反码.补码 原码:相信大家都会写,符号位在前二进制数值在后,凑够位数即可. 反码:原码符号位不变,其他 ...

  4. 十进制浮点数转换成IEEE754标准的32浮点数的二进制格式

    参考: http://jimmygod.blog.163.com/blog/static/43511339200792605627411/ http://blog.csdn.net/archersab ...

  5. IEEE754标准浮点数表示与舍入

    原文地址:https://blog.fanscore.cn/p/26/ 友情提示:本文排版不太好,但内容简单,请耐心观看,总会搞懂的. 1. 定点数 对于一个无符号二进制小数,例如101.111,如果 ...

  6. IEEE754标准浮点格式

    两种基本浮点格式:单精度和双精度.IEEE单精度格式具有24位有效数字,并总共占用32 位.IEEE双精度格式具有53位有效数字精度,并总共占用64位 两种扩展浮点格式:单精度扩展和双精度扩展.此标准 ...

  7. IEEE754标准

    以下计算按规格化规定: S:符号位 M:分数值 E:指数偏移值 单精度浮点数(32bit): NUM_single = (-1)^S *  1.M   *   2^(E-127) 双精度浮点数(64b ...

  8. 【转载】JS Number类型数字位数及IEEE754标准

    JS的基础类型Number,遵循 IEEE 754 规范,采用双精度存储(double precision),占用 64 bit.如图 意义 1位用来表示符号位 11位用来表示指数 52位表示尾数 浮 ...

  9. JS Number类型数字位数及IEEE754标准

    JS的基础类型Number,遵循 IEEE 754 规范,采用双精度存储(double precision),占用 64 bit.如图 意义 1位用来表示符号位 11位用来表示指数 52位表示尾数 浮 ...

随机推荐

  1. java读写excel文件( POI解析Excel)

    package com.zhx.base.utils; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi ...

  2. Java 之 Web前端(一)

    1.http a.定义:超文本传输协议 b.作用:web服务器与web浏览器之间通信 c.步骤: ①客户端与web服务器建立连接(IP地址与端口号) ②客户端发送http请求(请求资源路径) ③服务器 ...

  3. LYOI 2016 Summer 函数 【线段树】

    <题目链接> 题目大意: fqk 退役后开始补习文化课啦,于是他打开了数学必修一开始复习函数,他回想起了一次函数都是 f(x)=kx+b的形式,现在他给了你n个一次函数 fi(x)=kix ...

  4. Jenkins环境搭建(1)-下载与安装

    Jenkins简介 Jenkins是一个功能强大的应用程序,允许持续集成和持续交付项目,它是一个免费的源代码,可以处理任何类型的构建或持续集成.集成Jenkins可以用于一些测试和部署技术. Jenk ...

  5. 在web项目中搭建一个spring mvc + spring + mybatis的环境

    介绍:本文中示范搭建一个ssm环境的框架:使用流程就是客户端通过http请求访问指定的接口,然后由服务器接受到请求处理完成后将结果返回. 本项目请求流程细节介绍:由客户端请求到指定的接口,这个接口是个 ...

  6. 网络基础配置--开启SSH,关闭Telnet

    1.Telnet和SSH对比 1.1.TELNET 使用Telnet这个用来访问远程计算机的TCP/IP协议以控制你的网络设备相当于在离开某个建筑时大喊你的用户名和口令.很快会有人进行监听,并且他们会 ...

  7. MySQL firstmatch strategy

    在探讨subquery如 x IN (SELECT XX FROM TABLE)这样的形式的MATCH策略时,不是很清楚实现过程.在网上搜了一下, 地址:http://stackoverflow.co ...

  8. Codeforces.954I.Yet Another String Matching Problem(FFT)

    题目链接 \(Description\) 对于两个串\(a,b\),每次你可以选择一种字符,将它在两个串中全部变为另一种字符. 定义\(dis(a,b)\)为使得\(a,b\)相等所需的最小修改次数. ...

  9. MVC微型框架---------学习

    1.单一入口机制 是指在web程序中 所有的请求都指向一个脚本文件 2.工厂模式的概念精髓:工厂类就是对类的封装,类是对方法的封装,方法是对实现过程的封装调用当前类的静态方法,规范的写法是使用 sel ...

  10. VUE学习第一天,安装

    vue生命周期好文章: http://www.zhimengzhe.com/Javascriptjiaocheng/236707.html