【第22期】观点:IT 行业加班,到底有没有价值?

浮点数在内存中的存储(简述)

原创 2016年05月30日 13:34:44

数据类型:

1.基本类型(整形,浮点型,字符型)

2.构造类型(数组,结构体,联合,枚举)

3.指针类型

查看数据范围:整形范围(limits.h) 浮点型类型(flaot.h)

eg:有符号的char的表示范围:0000 0000~1111 1111(-128~127)其中最高位表示符号位,0为正 1为负

spacer.gif

其实数据的存储和访问就下像作图这个圈一样,当你给它的127+1它就会变成128

整形变量:

一般来说字长为32的情况下,整形表示32位,短整形16位,长整形32位

数据在计算机中以补码的形式存储

正数的原反补码均相同,负数的补码是它的反码+1得到

浮点数:

整数的存储我们都十分的熟悉,但浮点数在我们的计算机里是怎么存储的呢?

我们试着来实现以下程序:

int main()
{
     int num=9;
      float *p=(float *)#
     printf("%d",num);
     printf("%f",*p);
}

wKioL1ZN41SiM4HpAAAkHpNDtuA498.png



int main()
{
     int num;
      float *p=(float *)#
     *p=9.0;
     printf("%d",num);
     printf("%f",*p);
}

wKioL1ZN41Tz_eF8AAAhq5lfv5c867.png

为什么会出现这样的现象呢?

这很正常,因为浮点数在内存中的存储方式和我们的整形变量是完全不一样的

那么浮点数是怎么存放的呢

一般来说我们使用科学计数法将10进制浮点数表示成N.XXXX*10^M;

而浮点数在计算机里存放时,我们的计算机也将它表示成(-1)*S*M*2^E     

其中S表示符号位,M表示尾数,E表示指数

在字长32的计算机中

最高位存放符号位,中间8位存放指数部分,剩下的部分存放尾数。

我们来看看9.0在内存中是怎么存放的!

0100 0001  0001 0000 0000 0000 0000 0000

我们现在以浮点数的存储方式将它分开来看

0 10000010 001 00000000 00000000 00000000

第一位表示符号位 中间八位是阶码 最后紧跟存尾数

9.0在计算机里先表示为1001 以IEEE754标准表示成1.001*2^(3)

在我们存入内存时必须给我们的E加上中间数来调整,对于8位的E我们加上127来调整

所以中间部分表示为1000 0010 (3+127)

现在你会了吗?


版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

深入理解计算机系统-之-数值存储(五)--浮点数在内存中的存储方式

前景回顾前面我们了解到依据CPU的端模式的架构不同,数据的存储的字节序也不同 BE big-endian 大端模式,最直观的字节序 地址低位存储值的高位,地址高位存储值的低位 ,数据填写时,不要考...

浮点数在计算机中存储的方式

浮点数在计算机中的存储1996年6月4日,欧洲最新的无人驾驶火箭Ariane5初次航行时,发射后仅37秒,火箭偏离了它的飞行路径,解体并且爆炸。火箭上载有价值5亿美元的通信卫星。科学家们进行调查之后,...

浮点数在计算机中存储方式

转自 http://blog.csdn.net/wuna66320/article/details/1691734#comments http://cruih.iteye.com/blog/127...

C/C++中整数与浮点数在内存中的表示方式

在C/C++中数字类型主要有整数与浮点数两种类型,在32位机器中整型占4字节,浮点数分为float,double两种类型,其中float占4字节,而double占8字节。下面来说明它们在内存中的具体表...

计算机中整数和浮点数的表示和存储【大端小端的区别】

整数的表示当前较为流行的有2种。 补码计数法 余码计数法补码计数法在补码计数法中用最高位表示符号位,如果最高位为1那么表示负数,如果最高位是0,那么表示非负数。 举例说明: 大部分计算机都是32位...

一道面试题引发的问题:浮点数和整数在计算机种的存储方式

1.先看题目:     给出下面代码的输出:    [html] view plaincopy float a = 1.0f;   cout ...

算法竞赛入门经典------浮点数整数在内存中的存储方式

算法竞赛入门经典---浮点数整数在内存中的存储方式 参考文章:http://www.cnblogs.com/zxtp/p/4938742.html 1、数据的存储方式:大端模式和小端模式 ...

小数在计算机中的存储形式

前面一篇我们讲了位运算后,基本C语言的大块都提及了,一些细节和用法暂时不再本模块介绍了。希望我的心愿能够在我毕业之前给我的大学生涯划上一个圆满的句号。加油努力。   在本模块的第三篇就已经...

计算机中浮点数的存储方式-自己整理,欢迎大家批评指正

1、以32位float为例:计算机中表达浮点数时分为符号(s),指数(e),尾数(f)三部分,当表示32位float时各部分长度分别为:s(1位),e(8位),f(23位) 。浮点数大小是(-1)^s...

剖析整数,浮点数在内存中的存储

一:整数在内存中的存储  比如: int a = 10; int b =  -10; a分配了4个字节的空间,那如何存储呢? 首先,明确原码,反码,补码: 原码:直接将二进制按照正负数的形式翻译成...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)