模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断

模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断

ID:14407052

大小:101.00 KB

页数:4页

时间:2018-07-28

模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断_第1页
模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断_第2页
模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断_第3页
模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断_第4页
资源描述:

《模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、实验二模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断1、实验目的1)理解页式虚拟存储管理中的地址转换。2)理解用先进先出调度算法如何处理缺页中断。2、实验原理在页式虚拟存储管理中,如果访问的页面在内存,计算出相应的物理地址,如果访问的页面不在内存,产生缺页中断,将所缺页从外存调入,如果内存没有空间需要将内存的一页淘汰,再将所缺页调入,然后计算出相应的物理地址。3、实验仪器设备微型计算机、VisualC++开发软件4、实验内容与步骤编写程序,模拟页式虚拟存储管理中硬件的地址转换和用先

2、进先出调度算法处理缺页中断。假定主存的每块长度为1024个字节,现有一个共7页的作业,其副本已在磁盘上。系统为该作业分配了4个主存块,且该作业的第0页至第3页已经装入主存,其余3页尚未装入主存,该作业的页表见下表。页号标志主存块号修改标志在磁盘上的位置0150010118001221900133110021400022500023600125实验步骤1)输入程序2)如果该作业执行的指令序列如下表所示:操作页号页内地址操作页号页内地址+0072+40565+1050—5023╳2015存(save)103

3、7存(save)3026+2078取(load)0056—4001—6040存(save)6086执行上述的指令序列来调试你所设计的程序(仅模拟指令的执行,不必考虑指令序列中具体操作的执行)5、预习及实验报告要求预习页式虚拟存储管理中地址转换和页面置换算法的有关内容。实验报告要求写出程序的源代码及运行结果。分析:主存块有4个,物理地址=块号*块长(这里是1024)+块内地址(块内地址=页内地址),若页号不在主存中,则产生缺页中断,根据先进先出原则,今要执行的页号置换最先进入主存的页号,计算得到如下值:5

4、192,8242,9231,1050,5176,5160,8248,9239,1061,5198,8193,8278012306451246000006666222111111444446222222255555333333331111#definesize1024//定义块的大小,本次模拟设为1024个字节。#include"stdio.h"#include"string.h"#includestructplist{intnumber;//页号intflag;//标志,如为1表示该页

5、已调入主存,如为0则还没调入。intblock;//主存块号,表示该页在主存中的位置。intmodify;//修改标志,如在主存中修改过该页的内容则设为1,反之设为0intlocation;//在磁盘上的位置};//模拟之前初始化一个页表。structplistp1[7]={{0,1,5,0,010},{1,1,8,0,012},{2,1,9,0,013},{3,1,1,0,021},{4,0,-1,0,022},{5,0,-1,0,023},{6,0,-1,0,125}};//命令结构,包括操作符,页

6、号,页内偏移地址。structilist{charoperation[10];intpagenumber;intaddress;};//在模拟之前初始化一个命令表,通过程序可以让其顺序执行。structilistp2[12]={{"+",0,72},{"5+",1,50},{"*",2,15},{"save",3,26},{"load",0,56},{"-",6,40},{"+",4,56},{"-",5,23},{"save",1,37},{"+",2,78},{"-",4,1},{"save",6,

7、86}};main(){printf("模拟页式虚拟存储管理中硬件的地址转换和用先进先出调度算法处理缺页中断");inti,lpage,pflage,replacedpage,pmodify;intp[4]={0,1,2,3};intk=0;intm=4;longmemaddress;for(i=0;i<12;i++)//作业执行指令序列,12个{lpage=p2[i].pagenumber;//获取页号pflage=p1[lpage].flag;//标志,是否在内存中printf("%s,%d,%

8、d",p2[i].operation,p2[i].pagenumber,p2[i].address);printf("在主存块%d中执行",lpage);if(pflage==0)//如果页面不在内存中{printf("把页号%d",lpage);//置换replacedpage=p[k];pmodify=p1[replacedpage].modify;if(pmodify==1)printf("***放在页号%d的位置",replaced

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。