- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE
PAGE 11
模拟程序使用说明
一、虚拟页式存储管理模拟程序
例题:有一个虚拟页式存储管理,内存共4块可供使用,访问的页面次序:15、8、 9、5、 8、 1、9、6、2、7、15、1、5、8、9、2、3、6、9、4;空闲块号记作:1、2、3、4。
本例子采用先进先出调度算法,模拟页面的调进与调出。
操作过程:
(1)根据访问页面次序,依次选择(双击)图中左侧的页面编号,观察中间页表情况,并观察右侧磁盘块的使用情况。
如图当依次选择:15、8、 9、5时,中间部分页表如图,空间块表已无空闲块,内存块已分配1、2、3、4块,此时缺页中断次数为4。
(2)当选择的页面在内存中时,缺页中断次数不会发生变化,如果选择的页面不在内存中,缺页中断次数也分发生变化。
(3)依次选择:15、8、 9、5、 8、 1、9、6、2、7、15、1、5、8、9、2、3、6、9、4后,最后产生缺页中断次数为17。如图所示。
二、进程管理与控制
【例1】进程互斥,有三个售票点:南京、南宁、南昌,销售北京至东京的飞机票,采用进程互斥管理机制,实现进程之间的互斥访问临界区。
(1)初始状态:信息号S:=1;该航班余票数为A=4;初始信息如图。
(2)当选择“南京”时,北京到东京的余票数量为3;信号S=0;如图所示。
(2)此时,如果单击“南宁”,信号量S=-1;等待队列为“南宁”,当前用户为“南京”;提示信息“已有用户在买票,进入阻塞队列”,表示“南宁”进程进入“阻塞”状态。
(2)此时,如果单击“南晶”,信号量S=-2;等待队列为“南宁”和“南昌”,当前用户为“南京”;提示信息“已有用户在买票,进入阻塞队列”,表示“南宁”和“南昌”两进程进入“阻塞”状态。
(3)当单击“释放”按钮时,此时信号号S=-2+1=-1,释放一个等待信息号S的进程“南宁”,当前用户为“南宁”,等待队列有“南昌”,如图所示。
(4)当单击“释放”按钮时,此时信号号S=-1+1=0,释放一个等待信息号S的进程“南昌”,当前用户为“南昌”,等待队列无进程等待,如图所示。
【例2】进程同步问题一。父母使用一个信号SP实现互斥;父子之间设置一个信号SG实现同步;母子之间也设置同一个信号量SG实现同步。
begin
S,S1:semaphore;
B:integer;//代表果盘
SP:=1;
SG:=0
cobegin
process father
x:integer;
begin
L1:取一个苹果;
P(SP); //表示父母互斥访问果盘
B:=x;
V(SG); //通知儿子取苹果
goto L1
end;
process mother
y:integer;
begin
L2: 取一个香焦;
P(SP); //表示父母互斥访问果盘
B:=y;
V(SG); //通知儿子取香焦
goto L2
end;
process son
begin
L3: P(SG); //表示是否是父亲放的苹果
取B中的苹果或香焦;
P(SP);
吃苹果或香焦;
goto L3
end;
coend;
end;
操作过程:
(1)初始状态,如图。
(2)单击“父亲”按钮,父亲把“苹果”放入果盘中,通知“儿子”取苹果,“消费者”绿灯亮,“生产者”红灯亮。果盘中有“苹果”,如图所示。
(3)此时,母亲无法放香焦到果盘中,如果单击“母亲”按钮,则母亲无法放香焦到果盘中,如图所示,提示信息为“无果盘可用!请稍后再送。”。
(4)当儿子取走“苹果”后,父母可以再次放入水果于果盘中,如图所示。
(5)当母亲放香焦于果盘中,则出现如图所示界面。
【例3】进程同步问题二。父母使用一个信号S实现互斥,S初什值为3;父子之间设置一个信号S1实现同步;母子之间也设置一个信号量S1实现同步。
begin
S,S1,S2:semaphore;
B:integer;//代表果盘
Sp:=3;
SG:=0
cobegin
process father
x:integer;
begin
L1:取一个苹果;
P(SP); //表示父母互斥访问果盘
B:=x;
V(SG); //通知儿子取苹果
goto L1
end;
process mother
y:integer;
begin
L2: 取一个香焦;
P(SP); //表示父母互斥访问果盘
B:=y;
V(SG); //通知儿子取香焦
goto L2
end;
process son
begin
文档评论(0)