内存:内存可存放数据,程序执行前需要先放到内存中才能被 CPU 处理 -- 缓和 CPU 与硬盘之间的速度矛盾。
功能:
- 内存空间的分配与回收
- 地址转换
- 内存空间的扩充
- 存储保护
创建步骤:编译、链接、装入
链接的类型:静态链接、装入时动态链接、运行时动态链接
装入模式:绝对装入、可重定位装入、动态运行时装入
多道程序环境用来扩充内存的方法。
覆盖:将程序分为多个段,常用的段常驻内存,不常用的段需要时才调入内存
交换:内存中某些段移出内存,把外存中具备运行的装入内存
一个程序分配一个连续的内存空间
- 单一连续分配
- 固定分区分配
- 动态分区分配
- 首次适应算法
- 最佳适应算法
- 最坏适应算法
- 邻近适应算法
一个程序分散地装入不相邻的内存分区,根据分区大小是否固定,分为分页存储管理、分段存储管理。
分页存储管理根据运行时是否把作业的所有页面都装入内存才能运行,又分为基本分页存储管理方式、请求分页存储管理方式。
- 分页管理不会产生碎片
- 将主存空间划分为大小相等且固定的块,块相对较小,作为主存的基本单位,进程以块为单位空间申请。
- 按照用户进程中的自然段划分逻辑空间。
- 作业的地址空间首先被分为若干逻辑段,每段都有自己的段号
- 每个段分为若干大小固定的页
- 对内存空间的管理仍然和分页存储管理一样
- 会产生碎片
- 对程序员的透明性:分页透明,但是分段需要程序员显式划分每个段。
- 地址空间的维度:分页是一维地址空间,分段是二维的。
- 大小是否可以改变:页的大小固定,段的大小可以动态改变。
- 出现的原因:分页主要用于实现虚拟内存,从而获得更大的地址空间;分段主要是为了使程序和数据可以被划分为逻辑上独立的地址空间并且有助于共享和保护。
传统存储管理方式的特征:
- 一次性
- 驻留性
局部性原理:
- 时间局部性
- 空间局部性
虚拟存储器的定义:基于局部性原理,程序的一部分装入内存,一部分留在外存,需要的时候调入内存。
特征:多次性、对换性、虚拟性
实现:
- 请求分页存储管理
- 请求分段存储管理
- 请求段页式存储管理
系统建立在基本分页系统基础之上,为了支持虚拟存储器功能而增加了请求调页功能和页面置换功能
- 最佳置换算法(OPT)
- 先进先出页面置换算法(FIFO)
- 最近最久未使用置换算法(LRU)
- 时钟置换算法(CLOCK)
- 固定分配局部置换
- 可变分配全局置换
- 可变分配局部置换
刚换出的页面又要换入内存。
原因:
- 分配的物理页帧数不足(主要原因)
- 置换算法不当
某段时间内,进程要访问的页面集合。