数据存储(改进版)

简介: 数据存储(改进版)

知识回顾


在学习之前我想问大家一个问题,就是下面这个代码的运行结果是什么

int main()
{
  int n = 9;
  float* pFloat = (float*)n;
  printf("%d", n);
  printf("%f", *pFloat);
  *pFloat = 9.0;
  printf("%d", n);
  printf("%f", *pFloat);
  return 0;
}

怎么样,你是否能做出来呢?如果不能就请大家来复习复习前面的知识吧。


前面的学习就请大家转到这里来回顾一下https://developer.aliyun.com/article/1223088


那么这里我要补充的是当E全为0或者1的时候,我们取出来的时候又该怎么取呢?我们知道当我们在存储E的时候需要加上一个值,在32位机器上,我们需要加上127,而在64位机器上我们需要加上1023。相反的当我们拿出来的时候就需要减上一个值,当E为其他值就正常的减去就行了,可是当E为0或者1的时候,就需要不同的方法。


当E全为0时


如果还是按照常规的方式那么0-127=-127,2^-127是一个很小很小的数,它再乘上前面的数还是接近于0。所以我们就不能用常规的方法。


浮点数的指数E等于1-127或者是1-1023,而有效值的M不再加上第一位的1,而是还原成0.xxxxxx的小数。这样是为了表示+=0,以及接近于0的很小的数字。


当E全为1时


当存储的时候E全为1时,我们就可以把它看作+=无穷大,因为2^127本身就是一个相当大的数字,更不用说再乘上前面的数字,所以我们就可与把它看作是无穷大。


这些就是我补充的内容,希望能对你有所帮助

相关文章
|
7月前
|
存储 小程序 编译器
【数据存储:揭开内存中数据存储的神秘面纱】(上)
【数据存储:揭开内存中数据存储的神秘面纱】
|
7月前
|
存储
【数据存储:揭开内存中数据存储的神秘面纱】(下)
【数据存储:揭开内存中数据存储的神秘面纱】
|
6月前
|
存储 NoSQL 大数据
【大数据】LSM树,专为海量数据读写而生的数据结构
【大数据】LSM树,专为海量数据读写而生的数据结构
195 0
|
7月前
|
存储 小程序 编译器
深度剖析数据在内存中的存储
深度剖析数据在内存中的存储
69 1
|
7月前
|
存储 大数据 OLTP
将LSM-Tree与非易失内存(NVM)相结合的设计与实现
将LSM-Tree与非易失内存(NVM)相结合的设计与实现
115 1
|
7月前
|
存储
深度剖析数据在内存中的存储(超详细版){下}
深度剖析数据在内存中的存储(超详细版){下}
49 0
|
存储 Kubernetes 应用服务中间件
应用存储和持久化数据卷:核心知识(二)|学习笔记
快速学习应用存储和持久化数据卷:核心知识(二)
127 0
应用存储和持久化数据卷:核心知识(二)|学习笔记
|
存储 小程序 编译器
深度剖析数据在内存中的存储【超详解】
深度剖析数据在内存中的存储【超详解】
3902 0
|
存储 算法 固态存储
解析内存中的高性能图结构
在进行各种图处理、图计算、图查询的时候,内存或是硬盘中如何存储图结构是一个影响性能的关键因素。本文主要分析了几种常见的内存图结构,及其时间、空间复杂度。
213 0
|
存储 SQL 缓存
读书笔记《数据密集型应用系统设计》- 数据存储与检索
《数据密集型应用系统设计》是一本很好的介绍数据密集类系统设计原理的纲要性书籍,笔者再次阅读下,记录一些读书笔记,也写一些自己的思考穿插其中,以做备忘。
175 0