- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《操作系统》综合实训项目设计文档
基本信息
项目名称:段页式虚拟存储管理
完成人姓名:孙晓卉
学号:2011118004
完成日期:2014.5.29
一、实验内容与目的
1、内容
编写程序完成段页式虚拟存储管理存储分配、地址重定位和缺页中断处理。
(1)为一个进程的内存申请(多少个段,每个段多大)分配内存,当一个进程(完成)结束时回收内存;
(2)对一个给定逻辑地址,判断其是否缺段、缺页,若不缺段、不缺页,则映射出其物理地址;
(3)若缺段则进行缺段中断处理,若缺页则进行缺页中断处理。
假定内存64K,内存块(页框)大小为1K,进程逻辑地址空间最多4个段,每个段最大16K,进程驻留集大小为8页。假设进程运行前未预先装入任何地址空间,页面淘汰策略采用局部(驻留集内)置换策略。
输出每次存储分配/回收时,内存自由块分布情况、相关进程的段表和页表信息。
目的
(1)加深理解段页式虚拟存储管理的概念和原理。
(2)掌握段页式存储管理中存储分配(和回收)方法;
(3)深入了解段页式虚拟存储管理中地址重定位(即地址映射)方法。
(4)深入理解段页式虚拟存储管理中缺段、缺页中断处理方法。
二、主要设计思路和流程图
1、设计思路
(1)内存大小为64K,页框大小为1K,驻留集最多放8个页,在初始时所有块都空闲,并输出空闲状态和所有可用的空闲块。
(2)进程、段表和页表均用结构体数组存储,其中每个进程对应一个段表,每个段表可以有一个或多个页表。每次查询一个页时,要通过进程号找相应的段,通过段号找到该页。
(3)给出一个功能菜单,用户可以选择“创建进程”、“结束进程”、“查看内存”或地址映射。
(4)当用户选择“创建进程”时,现输入此次内存的总需求,即段号和相应的页数,并保存在一个全局的二维数组中,用于后面每个进程空间申请的数量的检查。用户分别输入进程号,每个进程需要的段数,段号和相应的页号,并标记好是否要调入驻留集。输入完成后,系统进行内存空间和驻留集空间的检查,若均未满,则分配成功;如果内存已满,则此次分配失败;如果驻留集已满,则修改溢出部分的标志位(即P位)。
(5)分配好空间后,将输出每个进程相应的段表和页表项。
(6)当用户选择“结束进程”时,清空该进程的段表和页表,修改标志位,释放掉在内存中的空间。
(7)当用户选择“查看内存”时,输出当前在内存中的进程个数、已用的内存块数和空闲的内存块数,并显示所用可用的空闲块。
(8)当用户选择“地址映射”时,先输入想查找的进程号,在检验正确的情况下,输入段号和段内偏移量,判断段的标志位,若该段不在驻留集中,则为虚段,进行缺段中断处理;若在驻留集中,检验偏移量是否越界,在不越界的前提下,根据偏移量计算页号并判断页的标志位,若该页不在驻留集中,则为虚页,进行缺页中断处理,若在驻留集中,则计算出相应的物理地址并输出。
2.程序流程图
(1)总体流程图
Menu();Init()
Menu();
Init()
othersExit;
others
Exit;
choice
choice
41
4
1
32
3
2
Finish_Pro()
Finish_Pro()
Check_Mem()Addr_Exchange()Apply_Mem()
Check_Mem()
Addr_Exchange()
Apply_Mem()
是否缺段、页页Alloc_Mem()
是否缺段、页页
Alloc_Mem()
否给出物理地址
否
给出物理地址
是
是
FIFO_Strategy() Print_Table()
FIFO_Strategy()
Print_Table()
Print_Table()
Print_Table()
进程创建流程图
Input seg_sum_num
Input seg_sum_num
Input seg_sum[i][0],seg_sum[i][0]输入段号和相应的页数
Input seg_sum[i][0],seg_sum[i][0]
输入段号和相应的页数
Input pro_numprocessCount += pro_numpro_num
Input pro_num
processCount += pro_numpro_num
pro_num =
pro_num = 0 ||
pro_num Pro_sum_size
pro_num = 0
pro_num = 0 pro_num Pro_sum_size
i = 0 , i pro_numInput Processes[i].pro_id;
i = 0 , i pro_num
Input Processes[i].pro_id;
Input Processes[i].Snum;
i++;
您可能关注的文档
最近下载
- 2025年辽宁省初中学业水平考试英语模拟试卷试题(含答案).pdf VIP
- 螺纹联接与螺旋传动介绍.ppt VIP
- 《大学美育》教案 第13课 光影流转的传奇 影视之美(二).docx VIP
- 小学生3500个常用汉字归类(带拼音).pdf VIP
- 《大学美育》教案 第12课 光影流转的传奇 影视之美(一).docx VIP
- 《大学美育》教案 第11课 五彩缤纷的世界:绘画之美(二).docx VIP
- Dahua大华以太网交换机(桌面式管理型)_WEB使用说明书_V1.0.0.pdf
- 党校中级考试资料.docx VIP
- (2025秋新版)人教版三年级数学上册全册教案.docx
- 智能体@AEI:Agentic Al,开启企业融合智简运维新范式.pdf
文档评论(0)