| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> 【C语言进阶】终极奥义 数据在内存中是这样存储的 -> 正文阅读 |
|
[C++知识库]【C语言进阶】终极奥义 数据在内存中是这样存储的 |
本章目录温馨提示大家好我是Cbiltps,在我的博客中如果有难以理解的句意,难以用文字表达的重点,我会有配图。所以我的博客配图非常重要!!! 如果你对我感兴趣请看我的第一篇博客! 本章重点
正文开始1. 数据类型详细介绍目前我们已经学习的基本内置类型和它的字节大小:
1.1类型的基本归类
浮点数家族:
构造类型:
指针类型:
空类型:
2. 整形在内存中的存储2.1原码、反码、补码要知道数据在所开辟内存中到底是如何存储的?要知道以下概念! 计算机中的整数有三种表示方法,即原码、反码和补码。 三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位负整数的三种表示方法各不相同。
2.2整数存储规则对于整形来说:数据存放内存中其实存放的是补码。
2.3关于大小端
为什么会有大小端? 在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit 。 但是在C语言中除了 8bit 的 char 之外,还有 16bi 的 short 型,32bit 的 long 型(要看具体的编译器)。 另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。 因此就出现了大端存储模式和小端存储模式。
代码如下:
2.4练习
3. 浮点型在内存中的存储常见的浮点数:
3.1 一个例子浮点数存储的例子:
3.2 浮点数存储规则根据国际标准IEEE(电气和电子工程协会) 754,任意一个二进制浮点数V可以表示成下面的形式:
举例来说: 十进制的5.0,写成二进制是101.0 ,相当于1.01×2^2 。那么,按照上面V的格式,可以得出s=0,M=1.01,E=2。 十进制的**-5.0**,写成二进制是-101.0 ,相当于-1.01×2^2 。那么,s=1,M=1.01,E=2。 但是,对于一些特殊的例子不在考虑范围内,如3.3等。 IEEE 754规定:
至于指数E,情况就比较复杂。
然后,指数E从内存中取出还可以再分成三种情况: E不全为0或不全为1:
E全为0:
E全为1:
3.3解释前面的例子
全文结束(尾声)恭喜你对于数据在内存中的存储有了全面的认识,如果你有不解的困惑,可以评论或者私信留言。 再次感谢你们的阅览观看,你们的支持就是我源源不断的动力! |
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 | -2024/12/26 17:18:26- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |
数据统计 |