程序地址空间:进程的虚拟地址空间 -----------------有图片C,D,E,F理解
虚拟地址空间:mm_struct,内存描述符
内存地址:内存区域的一个编号
程序地址空间:进程的虚拟地址空间---虚拟地址 mm_struct
我们所看到的程序地址空间实际是一个虚拟地址空间,是操作系统通过mm_struct这个结构体为进程描述的一个空间,该结构体有时候也称作内存描述符
{ ulong mem_size//内存空间大小
ulong code_start //代码段的起始位置
ulong code_end }//代码段的结束位置
每个程序都有一个“连续”的内存地址 分页式当剩余内存小于所需要运行的内存,
为什么要使用虚拟地址空间呢?
进程在通过访问虚拟地址进而获取变量数据,最终还是要去访问物理内存,因为“数据是存储在物理内存中的”
在虚拟地址和物理地址之间通过“页表”进行地址映射,转换得到物理地址。进而访问物理内存区域
通过映射之后,物理地址可就不一定连续了,通过这种映射转换的方式实现数据的离散存储提高内存利用率
“页表”中不但记录了虚拟地址和物理地址的映射关系,并且还记录了这块地址的属性实现内存访问控制(是否可读可写可执行等操作)
创建一个子进程的流程------写时拷贝技术:操作系统通过复制父进程创建子进程,子进程初始时与父进程指向同一块物理内存区域,当内存数据发生改变时,
会为子进程重新开辟内存,更新页表
进程的独立性:独立更加稳定
虚拟地址空间和页表的作用: 提高内存利用率;增加访问控制;保持进程独立性;
虚拟地址怎样转换成物理地址:
分段式内存管理:内存地址的构成---段号+段内偏移
段表--有很多的段表项(物理地址的起始地址)
分页式内存管理: 内存地址的构成---页号+页内偏移
页表--有很多的页表项
段页式内存管理: 段号+段内页号+页内偏移
段表项中又有段内页表起始地址
段内页表中又包含物理页号
分段式:通过地址中的段号去段表中找到段表项,通过段表项中物理起始地址加上地址中段内偏移获取到物理地址
分页式:通过地址中的页号找到页表项,通过页表项中的物理页号加上页内偏移获取到物理地址
段页式:通过段号在段表中找到段表项,通过段表项中的段内页表地址找到段内元素,通过地址中段内页号在段内页表中找到页表项,
通过页表中的物理页号与页内偏移组成物理地址
内存置换算法:
swap交换分区: 内存不够时,将内存中暂时不使用的数据置换到交换分区,腾出内存,处理数据
三种算法:FIFO: 先进先出
LFU: 最近最少频率未使用
LRU: 最近最久没使用
```![在这里插入图片描述](https://img-blog.csdnimg.cn/20190701160254380.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ0ODQwMDQ2,size_16,color_FFFFFF,t_70)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20190701160315596.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ0ODQwMDQ2,size_16,color_FFFFFF,t_70)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20190701160348842.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ0ODQwMDQ2,size_16,color_FFFFFF,t_70)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20190701160400708.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ0ODQwMDQ2,size_16,color_FFFFFF,t_70)
程序地址空间
最新推荐文章于 2023-04-02 12:14:23 发布