实验五动态页式存储管理实现过程的模拟

上传人:汽*** 文档编号:560055357 上传时间:2024-01-25 格式:DOC 页数:6 大小:47KB
返回 下载 相关 举报
实验五动态页式存储管理实现过程的模拟_第1页
第1页 / 共6页
实验五动态页式存储管理实现过程的模拟_第2页
第2页 / 共6页
实验五动态页式存储管理实现过程的模拟_第3页
第3页 / 共6页
实验五动态页式存储管理实现过程的模拟_第4页
第4页 / 共6页
实验五动态页式存储管理实现过程的模拟_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《实验五动态页式存储管理实现过程的模拟》由会员分享,可在线阅读,更多相关《实验五动态页式存储管理实现过程的模拟(6页珍藏版)》请在金锄头文库上搜索。

1、实验五动态页式存储管理实现过程的模拟一、实验目的与要求在计算机系统中,为了提高主存利用率,往往把辅助存储器(如磁盘)作为主存储器的扩充,使多道运行的作业的全部逻辑地址空间总和可以超出主存的绝对地址空间。用这种办法扩充的主存储器称为虚拟存储器。通过本实验帮助学生理解在分页式存储管理中怎样实现虚拟存储器;掌握物理内存和虚拟内存的基本概念;掌握重定位的基本概念及其要点,理解逻辑地址与绝对地址;掌握动态页式存储管理的基本原理、地址变换和缺页中断、主存空间的分配及分配算法;掌握常用淘汰算法。二、实验环境VC+6.0集成开发环境或java程序开发环境。三、实验内容模拟分页式虚拟存储管理中硬件的地址转换和缺

2、页中断,以及选择页面调度算法处理缺页中断。四、实验原理1、地址转换(1)分页式虚拟存储系统是把作业信息的副本存放在磁盘上,当作业被选中时,可把作业的开始几页先装入主存且启动执行。为此,在为作业建立页表时,应说明哪些页已在主存,哪些页尚未装入主存,页表的格式如图10所示:页号标志主存块号在磁盘上的位置图10 页表格式其中,标志-用来表示对应页是否已经装入主存,标志位=1,则表示该页已经在主存,标志位=0,则表示该页尚未装入主存。主存块号-用来表示已经装入主存的页所占的块号。在磁盘上的位置-用来指出作业副本的每一页被存放在磁盘上的位置。(2)作业执行时,指令中的逻辑地址指出了参加运算的操作存放的页

3、号和单元号,硬件的地址转换机构按页号查页表,若该页对应标志为“1”,则表示该页已在主存,这时根据关系式: 绝对地址=块号块长+单元号计算出欲访问的主存单元地址。如果块长为2的幂次,则可把块号作为高地址部分,把单元号作为低地址部分,两者拼接而成绝对地址。若访问的页对应标志为“0”,则表示该页不在主存,这时硬件发“缺页中断”信号,有操作系统按该页在磁盘上的位置,把该页信息从磁盘读出装入主存后再重新执行这条指令。(3)设计一个“地址转换”程序来模拟硬件的地址转换工作。当访问的页在主存时,则形成绝对地址,但不去模拟指令的执行,而用输出转换后的地址来代替一条指令的执行。当访问的页不在主存时,则输出“*

4、该页页号”,表示产生了一次缺页中断。该模拟程序的算法如图11。 查页表 否是该页标志=1?形成绝对地址输出“*”页号表示发生缺页中断输出绝对地址有后继指令?取下一条指令结束图11 地址转换模拟算法2、用先进先出(FIFO)页面调度算法处理缺页中断。(1)在分页式虚拟存储系统中,当硬件发出“缺页中断”后,引出操作系统来处理这个中断事件。如果主存中已经没有空闲块,则可用FIFO页面调度算法把该作业中最先进入主存的一页调出,存放到磁盘上,然后再把当前要访问的页装入该块。调出和装入后都要修改页表页表中对应页的标志。(2)FIFO页面调度算法总是淘汰该作业中最先进入主存的那一页,因此可以用一个数组来表示

5、该作业已在主存的页面。假定作业被选中时,把开始的m个页面装入主存,则数组的元素可定为m个。例如: P0,P1,.,Pm-1其中每一个Pi(i=0,1,.,m-1)表示一个在主存中的页面号。它们的初值为:P0:=0,P1:=1,.,Pm-1:=m-1用一指针k指示当要装入新页时,应淘汰的页在数组中的位置,k的初值为“0”。当产生缺页中断后,操作系统选择Pk所指出的页面调出,然后执行:Pk:=要装入页的页号;k:=(k+1) mod m;再由装入程序把要访问的一页信息装入到主存中。重新启动刚才那条指令执行。编制一个FIFO页面调度程序,为了提高系统效率,如果应淘汰的页在执行中没有修改过,则可不必把

6、该页调出(因在磁盘上已有副本)而直接装入一个新页将其覆盖。因此在页表中增加是否修改过的标志,为“1”表示修改过,为“0”表示未修改过,格式如图12: 页号 标志 主存块号 修改标志 再磁盘上的位置图12 页表格式图12 页表格式由于是模拟调度算法,所以,不实际启动输出一页和装入一页的程序,而用输出调出的页号和装入的页号来代替一次调出和装入的过程。3、用最近最少用(LRU)页面调度算法处理缺页中断。(1)在分页式虚拟存储系统中,当硬件发出“缺页中断”后,引出操作系统来处理这个中断事件。如果主存中已经没有空闲块,则可用LRU页面调度算法把该作业中最先进入主存的一页调出,存放到磁盘上,然后再把当前要

7、访问的页装入该块。调出和装入后都要修改页表页表中对应页的标志。(2)LRU页面调度算法总是淘汰该作业中距现在最久没有访问过的那一页,因此可以用一个数组来表示该作业已在主存的页面。数组中的第一个元素总是指出当前刚访问的页号,因此最久没被访问的页总是由最后一个元素指出。编制一个LRU页面调度程序,为了提高系统效率,如果应淘汰的页在执行中没有修改过,则可不必把该页调出。模拟调度算法不实际启动输出一页和装入一页的程序,而用输出调出的页号和装入的页号来代替。五、程序流程图把第一题中程序稍作修改,与FIFO页面调度和LRU页面调度模拟算法结合起来,程序流程图分别如图13和图14所示:开始取一条指令取指令中

8、访问的页号L 查页表 否(产生缺页中断)是该页标志=1?形成绝对地址是是存指令?否置L页修改标志为“1”输出绝对地址有后继指令?否是结束模拟硬件地址转换取下一条指令模拟FIFO页面调度j:=Pkj页修改标志为1输出“out j”输出“in L”Pk:=L, k:=(k+1) mod m修改页表图13 FIFO页面调度模拟算法是否是否否(产生缺页中断)是模拟LRU页面调度模拟硬件地址转换取一条指令开始该页标志=1?取指令中访问的页号L查页表形成绝对地址输出绝对地址有后继指令?取下一条指令是存指令?置L页修改标志为“1”结束j:=被淘汰的页号j页修改标志为1输出“out j”输出“in L”调整数组,j退出数组,L数组第一个元素中修改页表 图14 LRU页面调度模拟算法 /

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 商业/管理/HR > 销售管理

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号