预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共29页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

第八章虚拟存储管理技术实存储管理技术要求把进程全部装入内存才能运行,在运行过程中,会出现两种可能:1)要求运行的进程所需的内存空间大于系统的内存空间,只有部分进程能够装入内存运行,而其他进程只有留在外存中等待。2)逻辑地址空间大于存储空间的进程无法在系统中运行。两种解决方案:从物理上增加内存容量或从逻辑上扩充内存容量(虚拟存储)一、虚拟存储器的概念1、局部性原理局部性原理(principleoflocality):指程序在执行过程中的一个较短时期,所执行的指令地址和指令的操作数地址,分别局限于一定区域。–时间局限性–空间局限性局部性原理是实现虚拟存储器的理论基础。2、虚拟存储器•在程序装入时,不必将其全部读入到内存,而只需将当前需要执行的部分页或段读入到内存,就可让程序开始执行。•在程序执行过程中,如果需执行的指令或访问的数据尚未在内存(称为缺页或缺段),则由处理器通知操作系统将相应的页或段调入到内存,然后继续执行程序。•另一方面,操作系统将内存中暂时不使用的页或段调出保存在外存上,从而腾出空间存放将要装入的程序以及将要调入的页或段。只需程序的一部分在内存就可执行。所谓虚拟存储器,就是仅把进程的一部分装入内存便可运行的存储器系统,它具有请求调入功能和置换功能,是能从逻辑上对内存容量进行扩充的一种存储器系统。虚拟存储器的逻辑容量由系统的寻址能力和外存容量之和所决定。多次性:一个作业被分成多次调入内存运行;对换性:允许在作业的运行过程中进行换进、换出;虚拟性:能从逻辑上扩充内存容量,是用户“看到”的内存容量远大于实际大小。该特征是以上两个特征为基础的。二、请求分页式存储管理方式请求式分页也称虚拟页式存储管理,与纯分页存储管理不同,请求式分页管理系统在进程开始运行之前,不是装入全部页面,而是装入一个或零个页面,之后根据进程运行的需要,动态装入其它页面;当内存空间已满,而又需要装入新的页面时,则根据某种算法淘汰某个页面,以便装入新的页面。在分页式存储管理的基础上,增加了请求调页功能、页面置换功能而形成的页式虚拟存储系统。系统需要解决下面三个问题:•1)系统如何获知进程当前所需页面不在主存。•2)当发现缺页时,如何把所缺页面调入主存。3)当主存中没有空闲的页框时,为了要接受一个新页,需要把老的一页淘汰出去,根据什么策略选择欲淘汰的页面。1、请求分页式存储管理的基本概念1)基本原理运行前将一部分页面装入内存,另外一部分页面则装入外存。在程序运行过程中,如果所访问的页面不再内存中,则发生缺页中断,操作系统进行页面动态调度:a)找到被访问页面在外存中的地址。b)在内存中找一个空闲块,如果没有,则按照淘汰算法选择一个内存块,将此块内容写回外存,修改页表。c)读入所需得页面,修改页表。d)重新启动进程,执行被中断的指令。2)页表机制页表中除了页号和物理块,增加若干项,以完成调入功能和置换功能a)状态位P:指示该页是否已经调入内存,0表示该页已在内存,1表示该页不再内存。b)访问位A:纪录该页在一段时间内被访问的次数,或最近已经有多少时间没有访问,供置换算法选择页面时参考。c)修改为M:纪录该页面在调入内存后是否被修改过。d)外存地址:指出该页在外存上的地址,通常是物理块号,供调入该页时使用。3)地址变换机构图8-22、内存分配策略1)内存页面分配策略a)平均分配b)按进程大小比例分配c)按进程优先级比例分配d)按进程长度和优先级比例分配2)外存块的分配策略静态分配:一个进程在运行前,将所有页面全部装入外存。当一个外存页面被调入内存,所占用的外存页面不释放。动态分配:一个进程运行前,仅将没有装入内存的部分装入外存,当某页面被调入内存时,释放所占用的外存空间。3、页面调入时机1)请求调页策略发生缺页中断时进行页面调度2)预调页策略每次调入若干个页面4、页面调度算法1)最佳置换算法(OPT)选择“未来不再使用的”或“在离当前最远位置上出现的”页面被置换。这是一种理想情况,是实际执行中无法预知的,因而不能实现。可用作性能评价的依据。假定系统为某进程分配了三个物理块,并考虑有以下的页面号引用串:7,0,1,2,0,3,0,4,2,3,0,3,2,1,2,0,1,7,0,12)先进先出置换算法(FIFO)选择建立最早的页面被置换。可以通过链表来表示各页的建立时间先后。性能较差。较早调入的页往往是经常被访问的页,这些页在FIFO算法下被反复调入和调出。•Belady现象:采用FIFO算法时,如果对一个进程未分配它所要求的全部页面,有时就会出现分配的页面数增多,缺页率反而提高的异常现象。•Belady现象的描述:一个进程P要访问M个页,OS分配N个内存页面给进程P;对一个访问序列S,发生缺页次数为PE(S,N)。当N增大时,PE(S,N)时而增大,时而减小。