| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> 【get C】数据在内存是如何存储的 -> 正文阅读 |
|
[C++知识库]【get C】数据在内存是如何存储的 |
? 👨?🏫文章目录 🚴?♀?前言
🚴?♀?数据类型介绍为什么需要有这些数据类型? 数据类型解决了数据存储的问题。 🚴?♀?整形数据在内存中存储整数中有三种二进制表示形式,分别是原码、反码、补码,正整数的原码 = 反码 = 补码,通常取最高位作为符号位。 原码:直接将正负整数按照二进制形式转换即可。
补码:负整数的补码将原码的符号位不变,其它位依次取反。
反码:负整数的反码在补码的基础上+1
对于整形数据来说:数据存放的实际是存放补码。 当我们定义变量时,系统会根据变量的数据类型,给变量开辟空间。这也是为什么要引入数据类型这个概念。 1.举例:5是如何存储到内存中
2.举例:-10是如何存储到内存中的?
?如何取出数据? 取出数据首先要知道数据的地址,得到地址后,如何确定取出范围,由变量的数据类型来决定。
为什么要使用补码的形式存储? 在计算机中CPU有中,只有加法器。以补码形式存储,符号位参与运算,既可以计算减法也可以计算加法。 大端存储模式:指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中。 小端存储模式:指数据的低位保存在内存的低地址中,而数据的高位,保存在内存的高地址中。 ?大小端主要由处理器决定,与编译器,操作系统这些没有直接的关系。 🚴?♀?浮点型数据在内存存储
类似于科学计数法:1090 = 1.090*10^3? IEEE754规定单精度浮点型和双精度浮点型存储模型 IEEE 754对有效数字M和指数E,还有一些特别的规定。 1<=M<2,M可以写成1.xxxxxx的形式,xxxxxx表示小数部分。 IEEE754规定,在计算机内部保存M时,默认这个数的第一位总是1,因此可以舍去,只保存后面的xxxxxx部分。在读取时,再把第一位添上。节省一位有效数字. 对于指数E,情况比较多。 首先E为无符号整数,如果E为八位,取值范围时0~255,E为11位,取值范围为0~2047,但是再科学计数法中E可以出现负数,所以IEEE 754则规定,存入内存E的真实数必须加上一个中间数,对于八位的E,中间数为127,对于11位的E,中间数位1023。例如2^13的E是13,所以在保存E时,必须保存成13+127 = 140,即10001100。 指数E从内存中取出还可以分为3种情况 😁1.E不全为0或不全为1 这时浮点数就采用下面的规则表示,即指数E的计算值减去127(或1023),得到真实值,再将有效数字M前加上第一位的1。 比如: 0.5的二进制位0.1,由于规定整数部分1<=M<2,即第一位必须位1,则将小数点右移一位,则为1.0*2^(-1),E的实际存储位-1+127,E的实际存储为01111110,M = 1.0,小数部分为0,M的存储为23位00000000000000000000000。 则0.5的二进制表示形式位:
🍞2.E全为0 这时,浮点数的指数E等于1-127(或者1-1023),即为真实值 有效数字M不再加上第一位的1,而是还原位0.xxxxxx的小数,这样可以表示0,以及接近于0的很小数字。 🧀3.E全为1 如果有效数字M全位0,表示无穷大。 举例: 10.0转化为二进制形式为1010.0,相当于:1.010*2^3,按照标准格式 可得S = 0,M = 1.010,E = 3。 举例1:7.25是如何存储到内存中的呢? 首先将7.25转化为二进制111.01 写成标准形式:1.1101*2^2 S = 0,M = 1101,E = 2+127
验证:? 有误的地方还请批评指正。? |
|
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图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/11 0:26:52- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |