101《操作系统课程设计》指导书.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《操作系统原理》课程设计参考 2010年12月 课设的目的 操作系统是计算机专业的一门专业课,也是计算机专业考研课程,但操作系统比较抽象,有的同学一学期完了都还很难理解进程、内存管理等一些概念和原理,操作系统课程设计的目的就是通过设计的实验,让同学们真正理解进程的实现,内存管理的机制,达到理解概念,了解实现原理。同时也进一步巩固程序设计与数据结构的实践技能,实现整个大学阶段实践技能不断线的目的。 课设的故事 一个操作系统采用请求页式管理方式来管理内存。当一个进程在运行中,随着进程的执行,它会不断的访问内存(代码执行、存取数据),这样就会提出内存访问请求。操作系统会根据用户进程提出的访存请求,来做地址变换,从而访问到用户进程想要访问的代码或数据。操作系统进行地址变换的过程中发现用户将要访问的地址所在的虚页还没有进入内存会自动将该虚页从磁盘中装入内存,再进行地址变换。当然若新的页调入内存之前,该进程所能使用的最大内存块数已经用完的话,操作系统就会从该进程已经在内存的那些页中根据先进先出的原则来淘汰掉一个页,腾出空间给将要正要请求访问的页。所以操作系统要记录每个进程的每个页面的状态,记录这些调入内存的页面的顺序,还要记录内存中各个块的使用情况。这些都是操作系统必需动态维护的数据,是操作系统的信息基础。 现假设一个计算机系统有内存m KB,系统的页面大小为1KB,假设操作系统占用内存低端的n个块(nm/5),剩余的内存空间采用“随机+顺序”的方式来获取未用内存块,以分配给块请求程序。 所谓“随机+顺序”的内存块分配方式就是用随机数来确定一个起始探测的开始块号,如果其已经被分配,则向下一块探测,如果还是已经分配,则继续下探,直到找到可用块,如果已经到内存的尾部则回到操作系统分界处继续下探。 操作系统采用固定可用块数的方式给每个进程使用和分配内存块,并且规定最大内存块数为x,当某个进程已经用完了它的最大内存块数后就要淘汰页面了。 模拟计算机系统允许最大并发进程数为y,假设目前进程数已经达到最大进程数。 为了模拟某个进程,其所需的页面数z由随机数产生(m/10 z m/4),页面推进的过程采用随机数方式给出访存地址a,逻辑地址a应该在0到zKB-1之间,操作系统负责对逻辑地址a进行地址变换,并维护整个系统内存管理的所有数据结构,保证进程的顺利推进,使内存得以共享,实现虚拟存储器的功能。 要求课设实现的系统能够配置上述参数,并按照配置参数的规模来系统的模拟系统的运行过程。希望可以可视化的展示系统内部的变化。 课设的方案 1构造页面、进程、内存管理所需的数据结构,动态管理系统中的有关信息。 #define MAX_MEMORY_FRAME_COUNT 200 //最大允许设置的内存大小(以块为单位) class CPage : public CObject //逻辑页的信息 { DECLARE_DYNCREATE(CPage) public: CPage(); bool bInMemoryFlag;//该页是否在内存 int nFrameNo;//内存的快号 int nDiskRelBlockNo;//磁盘的相对块号(可以随机给定) int nNextPageNo;//下一调进内存页的页号 bool bModifiedFlag;//修改位(可以随机给定) //... }; class CProcess : public CObject //进程的信息 { DECLARE_DYNCREATE(CProcess) public: CProcess(); void InitProcessParameter(int no,int pagetotal,int runtime); int GetOneLogicalAddress();//得到下一要访问的页的页号 void AddressMapping(int LogicalAddress); int nPID;//进程标识符 char szProcessName[20];//进程名 int nControlNo; int nStatus; int nPageCountLogicalSpace;//逻辑地址空间的页数 int nPageCountInMemory;//调入内存的页数 int nRunTime;//运行时间(运行步数) int nPageNoHead;//调入内存的首页 int nPageNoTail;//调入内存的末页 //其他信息,如就绪或阻塞队列指针自己可以根据自己的能力与爱好进一步完善下去 CPage* PageTable; }; int MaxFrameCount; int GetOneRandDiskNo()//随机产生一个虚页

文档评论(0)

donglian + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档