C/C++浮点数在内存中的存储方式
一、内存表示
任何数据在内存中都是以二进制的形式存储的,浮点数的表示是把一个数的有效数字和数的范围在计算机的一个存储单元中分别予以表示,数的小数点位置随比例因子的不同而在一定范围内自由浮动。如下图是32位和64位浮点数的表示方法:

在介绍浮点数的存储方式之前我们先介绍下阶码和尾数。
阶码:表达指数部分,用整数形式表示,指明小数点在数据中的位置,决定浮点数的表示范围。
尾数:用定点小数表示,给出有效数字的位数决定了浮点数的表示精度。
理论上,一个十进制数N可以写成N=10e×M,一个R进制数N可以写成N=Re×M,(M 尾数,e 指数,R 基数)例如:156.78=15.678×101=1.5678×102= 0.15678×103=RE×M,那么计算机中究竟采用哪种数据形式呢?
对于二进制数
1011.1101 =0.10111101 ×2+4
= 10.111101 ×2+2
= 1.0111101 ×2+3 (规格化表示法)
= 1.0111101 ×2+11 (11表示二进制的3)(规格化表示法)
=RE×M
根据IEEE754标准,规格化表示原则如下。
1、尾数最高有效位为1,隐藏,并且隐藏在小数点的左边(即:1≤M<2)
2、32位单精度浮点数规格化表示x=(-1)s×(1.M)×2E-127
e=E-127(E=e+127)
3、64位双精度浮点数规格化表示x=(-1)s ×(1.M)×2E-1023
e=E-1023(E=e+1023)
指数真值e 用偏移码形式表示为阶码E。
例1:浮点机器数(41360000)16,求真值。
①十六进制数展开成二进制数
0 100 0001 0011 0110 0000 0000 0000 0000
S(1位) 阶码E(8位) 尾数M(23位)
②指数e=阶码-127 =1000 0010-01111111=00000011=(3)10
③包括隐藏位1的尾数1.M =1.011011
④X=(-1)s×1.M×2e=+(1.011011)×23=+1011.011=(11.375)10
例2:真值20.59375,求32位单精度浮点数。
①分别将整数和分数部分转换成二进制数。
20.59375=10100.10011
②移动小数点,使其在第1、2位之间。
10100.10011=1.010010011×24
e=4
S=0
E=4+127=131=10000011
M=010010011
③得到32位浮点数的二进制存储格式为:
01000001101001001100000000000000=(41A4C000)16
二、表示范围
32位单精度浮点数表示范围:
E=1(0000 0001)~254(1111 1110) E全为1是用来通知异常情况。
e=-126~+127
表达的数据范围(绝对值):
最小值:e=-126,M=0(1.M=1)
十进制表达:2-126≈1.18×10-38
最大值:e=127,M=11…1(23个1)
1.M=1.11…1(23个1)=2-2-23
十进制表达:(2-2-23)×2127≈2×2127≈3.40×1038
64位单精度浮点数表示范围:
E=1~2046 E全为1是用来通知异常情况。
e=-1022~+1023
表达的数据范围(绝对值):
最小值:e=-1022,M=0(1.M=1)
十进制表达:2-1022≈2.23×10-308
最大值:e=1023,M=11…1(52个1)
1.M=1.11…1 (52个1)=2-2-52
十进制表达:(2-2-52)×21023≈ 2×21023≈1.79×10308
C/C++浮点数在内存中的存储方式的更多相关文章
- <转载>浅谈C/C++的浮点数在内存中的存储方式
C/C++浮点数在内存中的存储方式 任何数据在内存中都是以二进制的形式存储的,例如一个short型数据1156,其二进制表示形式为00000100 10000100.则在Intel CPU架构的系统中 ...
- C语言中浮点数在内存中的存储方式
关于多字节数据类型在内存中的存储问题 //////////////////////////////////////////////////////////////// int ,short 各自是4. ...
- Float在内存中的存储方式及IEC61131处理
Float在内存中的存储方式及IEC61131处理 1,fp32(32bits float)类型数据在存储器中占用4Bytes存储,且遵循IEEE-754标准: 一个浮点数分三部分组成: 符号位s(1 ...
- QList介绍(QList比QVector更快,这是由它们在内存中的存储方式决定的。QStringList是在QList的基础上针对字符串提供额外的函数。at()操作比操作符[]更快,因为它不需要深度复制)非常实用
FROM:http://apps.hi.baidu.com/share/detail/33517814 今天做项目时,需要用到QList来存储一组点.为此,我对QList类的说明进行了如下翻译. QL ...
- 数据在内存中的存储方式( Big Endian和Little Endian的区别 )(x86系列则采用little endian方式存储数据)
https://www.cnblogs.com/renyuan/archive/2013/05/26/3099766.html 1.故事的起源 “endian”这个词出自<格列佛游记>.小 ...
- float和double在内存中的存储方式
本文转载于:http://wenku.baidu.com/link?url=ARfMiXVHCwCZJcqfA1gfeVkMOj9RkLlR9fIexbgs9gDdV8rIS48A1_xe1y6YgX ...
- C/C++中整数与浮点数在内存中的表示方式
在C/C++中数字类型主要有整数与浮点数两种类型,在32位机器中整型占4字节,浮点数分为float,double两种类型,其中float占4字节,而double占8字节.下面来说明它们在内存中的具体表 ...
- C/C++数据在内存中的存储方式
目录 1 内存地址 2 内存空间 在学习C/C++编程语言时,免不了和内存打交道,在计算机中,我们存储有电影,文档,音乐等数据,这些数据在内存中是以什么形式存储的呢?下面做一下简单介绍. 本文是学 ...
- C++成员函数在内存中的存储方式
用类去定义对象时,系统会为每一个对象分配存储空间.如果一个类包括了数据和函数,要分别为数据和函数的代码分配存储空间.按理说,如果用同一个类定义了10个对象,那么就需要分别为10个对象的数据和函数代码分 ...
随机推荐
- 读谭浩强C语言数据结构有感(1)
1.什么是数据结构? 数据结构,就是我们计算机内部的运算,编程语言的基础工作模式吧,个人总结的 = = !! 数据:说简单一点,就是计算机二进制机器码,然后通过一些复杂的操作,变为复杂的语言. 数据元 ...
- Linux下使用FreeTDS访问MS SQL Server 2005数据库(包含C测试源码)
Linux下使用FreeTDS访问MS SQL Server 2005数据库(包含C测试源码) http://blog.csdn.net/helonsy/article/details/7207497 ...
- 【Python实战】Scrapy豌豆荚应用市场爬虫
对于给定的大量APP,如何爬取与之对应的(应用市场)分类.描述的信息?且看下面分解. 1. 页面分析 当我们在豌豆荚首页搜索框输入微信后,会跳转到搜索结果的页面,其url为http://www.wan ...
- 多说使用ua-parser-js显示浏览器和系统信息
前言 昨天博客接入了评论系统,使用的是国内的多说. 之前看到过有些利用该评论系统的有浏览器和系统信息的显示,感觉很不错. 所以,也想有这样的效果. 问题 多说如何显示浏览器和系统的信息? 解决方法 经 ...
- 背水一战 Windows 10 (35) - 控件(弹出类): FlyoutBase, Flyout, MenuFlyout
[源码下载] 背水一战 Windows 10 (35) - 控件(弹出类): FlyoutBase, Flyout, MenuFlyout 作者:webabcd 介绍背水一战 Windows 10 之 ...
- POJ-3061
算法: 1. 定义两个整数N和S,输入序列长度到N,输入最小子序列和下界到S. 2. 定义一个数组arr[100002],从arr[1]开始依次输入N个序列元素到arr. 3. 定义一个整数ans,初 ...
- Java--JDK动态代理核心源码解析
1.首先我们了解一下JDK动态代理的使用方法: public static void main(String[] args) { /** * 创建一个Bean对象,该对象实现BeanInterFace ...
- PHP函数之自定义函数
像数学中的函数一样,y=f(x)是函数基本的表达形式,x可看做是参数,y可看做是返回值,即函数定义就是一个被命名的.独立的代码段,它执行特定的任务,并可能给调用它的程序返回一个值. 自定义函数 函数的 ...
- Dumpbin 工具的使用
dumpbin用法:dumpbin /exports /out:d:\mfc90.txt d:\mfc90.lib 在使用VC时,可以用DUMPBIN.EXE来得到某个DLL中所输出的符号的清单.如下 ...
- [python]数据整理,将取得的众多的沪深龙虎榜数据整一整
将昨日取得的众多的沪深龙虎榜数据整一整 提取文件夹内所有抓取下来的沪深龙虎榜数据,整理出沪深两市(含中小创)涨幅榜股票及前5大买入卖出资金净值,保存到csv文件 再手动使用数据透视表进行统计 原始数据 ...