C++01(虚拟地址空间布局)


参考书籍:程序员的自我修养

1.计算机

32位操作系统---->计算机一次能处理的数据最大的位数 32bit
64位操作系统----> 64bit
也就是ALU宽度:算术逻辑单元
数据总线 (可以理解为字节) 地址总线(可以理解为指针)

2.程序运行需要什么?

指令+数据

3.CPU能识别什么?

语言分为三类:1.机器语言—>0,1码、2.低级语言–>汇编语言3.高级语言—>C/C++语言
CPU只能识别机器语言
.c/.cpp源文件------>.exe可执行文件要经历下列五个过程:
1.预编译:处理#开头的东西
1.宏定义–>先删除宏,然后进行文本替换。(宏定义不安全,没有类型检查和安全检查)
2.头文件–>将头文件中的内容递归展开。
3.处理预编译指令。(#if,#endif)
4.删除注释。
5.添加行号和文件标识。(错误发生时,能够快速定位)
6.保留#pragma指令,让编译器来做。---------->变成了.i文件(预编译文件)
命名规则:1.字母数字下划线。2.数字不能做首字母
2.编译:
1.词法分析
2.语法分析(一行表达式)(每种语言都有自己的语法)
3.语义分析(结合上下文)
4.代码优化
5.生成汇编指令(低级语言)--------->.s文件
3.汇编:翻译指令(把低级语言翻译成机器语言)—>.o(目标文件,可重入的二进制文件)
4.链接:
5.运行:

现在的计算机都是x86体系
最开始的80286操作系统---->实模式:程序加载到内存中,你看到的地址就是真实的地址。
内存是平坦的(连续的)
如下图:实模式下,如果A是恶意进程,将会损坏B中的内容
因此:进程保护欠缺。
实模式
因此之后提出了80386体系之后都是保护模式
x86体系:保护模式
虚拟地址空间
保护模式
1.虚拟地址空间:进程中看到的地址不是真实的地址
虚拟地址空间布局
虚拟地址空间:
虚拟: 不存在 看得见(通过其他方式,表示出来)
透明: 存在 看不见
物理: 存在 看得见

以Linux的32位操作系统为例
Linux内存空间 3:1
用户空间:内核空间
Windows 2:2

空指针不能解引用:原因如下图
全局变量,静态全局变量,静态局部变量都是数据,存放在数据段
普通的局部变量是指令!!!!!!----->.text 解释:运行前过程:所有数据都在文件中,运行后才有内存->栈区。
.data:已经初始化且初始化不为0的数据
.bss:未初始化或者初始化为0的数据
函数名是指令------>.text段
空指针不能解引用.png
虚拟地址空间布局划分(可以理解为内存和程序的中间层):

虚拟地址空间布局
笔记总结:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值