【操作系统】24王道考研笔记——第三章 内存管理

第三章 内存管理

一、内存管理概念

1.基本概念

【操作系统】24王道考研笔记——第三章 内存管理_第1张图片

【操作系统】24王道考研笔记——第三章 内存管理_第2张图片

2.覆盖与交换

覆盖技术:

【操作系统】24王道考研笔记——第三章 内存管理_第3张图片

【操作系统】24王道考研笔记——第三章 内存管理_第4张图片

交换技术:

【操作系统】24王道考研笔记——第三章 内存管理_第5张图片

【操作系统】24王道考研笔记——第三章 内存管理_第6张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第7张图片

3.连续分配管理方式

单一连续分配

【操作系统】24王道考研笔记——第三章 内存管理_第8张图片

固定分区分配

【操作系统】24王道考研笔记——第三章 内存管理_第9张图片

【操作系统】24王道考研笔记——第三章 内存管理_第10张图片

动态分区分配

【操作系统】24王道考研笔记——第三章 内存管理_第11张图片

动态分区分配算法:

【操作系统】24王道考研笔记——第三章 内存管理_第12张图片

【操作系统】24王道考研笔记——第三章 内存管理_第13张图片

【操作系统】24王道考研笔记——第三章 内存管理_第14张图片

【操作系统】24王道考研笔记——第三章 内存管理_第15张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第16张图片

4.基本分页存储管理

定义:

【操作系统】24王道考研笔记——第三章 内存管理_第17张图片

页表:

【操作系统】24王道考研笔记——第三章 内存管理_第18张图片

地址转换的实现:

【操作系统】24王道考研笔记——第三章 内存管理_第19张图片

子问题:

【操作系统】24王道考研笔记——第三章 内存管理_第20张图片

逻辑地址结构:

【操作系统】24王道考研笔记——第三章 内存管理_第21张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第22张图片

5.基本地址变换机构

流程:

【操作系统】24王道考研笔记——第三章 内存管理_第23张图片

原理:

【操作系统】24王道考研笔记——第三章 内存管理_第24张图片

例子:

【操作系统】24王道考研笔记——第三章 内存管理_第25张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第26张图片

6.具有快表的地址变换机构

快表,又称联想寄存器(TLB, translation lookaside buffer ),是一种访问速度比内存快很多的高速缓存(TLB不是内存!),用来存放最近访问的页表项的副本,可以加速地址变换的速度。与此对应,内存中的页表常称为慢表。

流程:

【操作系统】24王道考研笔记——第三章 内存管理_第27张图片

原理:

【操作系统】24王道考研笔记——第三章 内存管理_第28张图片

局部性原理:

【操作系统】24王道考研笔记——第三章 内存管理_第29张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第30张图片

7.两级页表

【操作系统】24王道考研笔记——第三章 内存管理_第31张图片

【操作系统】24王道考研笔记——第三章 内存管理_第32张图片

8.基本分段存储管理方式

分段:

进程的地址空间:按照程序自身的逻辑关系划分为若干个段,每个段都有一个段名(在低级语言中,程序员使用段名来编程),每段从0开始编址 。

内存分配规则:以段为单位进行分配,每个段在内存中占据连续空间,但各段之间可以不相邻。

【操作系统】24王道考研笔记——第三章 内存管理_第33张图片

段表:

【操作系统】24王道考研笔记——第三章 内存管理_第34张图片

地址变换:

【操作系统】24王道考研笔记——第三章 内存管理_第35张图片

【操作系统】24王道考研笔记——第三章 内存管理_第36张图片

对比:

【操作系统】24王道考研笔记——第三章 内存管理_第37张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第38张图片

9.段页式管理方式

分别的优缺点:

image.png

逻辑地址结构:

【操作系统】24王道考研笔记——第三章 内存管理_第39张图片

【操作系统】24王道考研笔记——第三章 内存管理_第40张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第41张图片

二、虚拟内存管理

1.基本概念

【操作系统】24王道考研笔记——第三章 内存管理_第42张图片

【操作系统】24王道考研笔记——第三章 内存管理_第43张图片

2.请求分页管理方式

请求分页存储管理与基本分页存储管理的主要区别:

  • 在程序执行过程中,当所访问的信息不在内存时,由操作系统负责将所需信息从外存调入内存,然后继续执行程序。
  • 若内存空间不够,由操作系统负责将内存中暂时用不到的信息换出到外存

机制:

【操作系统】24王道考研笔记——第三章 内存管理_第44张图片

缺页中断机构:

缺页中断是因为当前执行的指令想要访问的目标页面未调入内存而产生的,因此属于内中断 。

一条指令在执行期间,可能产生多次缺页中断。(如:copy A to B,即将逻辑地址A中的数据复制到逻辑地址B,而A、B属于不同的页面,则有可能产生两次中断)

【操作系统】24王道考研笔记——第三章 内存管理_第45张图片

地址变换机构:

【操作系统】24王道考研笔记——第三章 内存管理_第46张图片

【操作系统】24王道考研笔记——第三章 内存管理_第47张图片

【操作系统】24王道考研笔记——第三章 内存管理_第48张图片

3.页面置换算法

请求分页存储管理与基本分页存储管理的主要区别:

  • 在程序执行过程中,当所访问的信息不在内存时,由操作系统负责将所需信息从外存调入内存,然后继续执行程序。
  • 若内存空间不够,由操作系统负责将内存中暂时用不到的信息换出到外存。

此时使用页面置换算法决定应该换出哪个页面

【操作系统】24王道考研笔记——第三章 内存管理_第49张图片

最佳置换算法可以保证最低的缺页率,但实际上,只有在进程执行的过程中才能知道接下来会访问到的是哪个页面。操作系统无法提前预判页面访问序列。因此,最佳置换算法是无法实现的。

【操作系统】24王道考研笔记——第三章 内存管理_第50张图片

【操作系统】24王道考研笔记——第三章 内存管理_第51张图片

【操作系统】24王道考研笔记——第三章 内存管理_第52张图片

【操作系统】24王道考研笔记——第三章 内存管理_第53张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第54张图片

4.页面分配策略

页面分配:

【操作系统】24王道考研笔记——第三章 内存管理_第55张图片

【操作系统】24王道考研笔记——第三章 内存管理_第56张图片

【操作系统】24王道考研笔记——第三章 内存管理_第57张图片

【操作系统】24王道考研笔记——第三章 内存管理_第58张图片

抖动(颠簸)现象:

【操作系统】24王道考研笔记——第三章 内存管理_第59张图片

工作集:

【操作系统】24王道考研笔记——第三章 内存管理_第60张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第61张图片

5.内存映射文件

传统的:

【操作系统】24王道考研笔记——第三章 内存管理_第62张图片

内存映射文件:

【操作系统】24王道考研笔记——第三章 内存管理_第63张图片

总结:

【操作系统】24王道考研笔记——第三章 内存管理_第64张图片

主要参考:王道考研课程
后续会持续更新考研408部分的学习笔记,欢迎关注。
github仓库(含所有相关源码):408数据结构笔记

你可能感兴趣的:(操作系统,考研,笔记,操作系统)