




已阅读5页,还剩10页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
目录一、设计系统目的1二、设计系统要求1三、 系统分析1四、系统设计1五、程序设计流程图5六、 源程序清单5七、调试过程中的问题及系统测试情况121、调试过程122、系统测试结果12八、 系统设计总结14一、设计系统目的 本设计的目的是加深对进程概念及进程管理各部分内容的理解,熟悉进程管理中主要数据结构的设计及进程调度算法、进程控制机构、同步机构及通讯机构实施。 二、设计系统要求 设计一个允许n个进程并发运行的进程管理模拟系统。该系统包括有简单的进程控制、同步与通讯机构,其进程调度算法可任意选择。每个进程用一个PCB表示,其内容根据具体情况设置。各进程之间有一定的同步关系可选。系统在运行过程中应能显示或打印各进程的状态及有关参数的变化情况,以便观察诸进程的运行过程及系统的管理过程。 三、 系统分析 本系统实现的功能有 1、进程控制和同步等 可以控制进程的就绪执行和阻塞三种状态等基本功能。 2、进程调度 调度算法采用的是先来先服务算法。 3、进程在运行过程中状态变化的屏幕输出 输出的内容包括就绪的进程队列,当前cup正在执行的进程,被阻塞的进程队 列。 四、系统设计 本系统所包括的数据结构是对列类 本系统由于需要输出就绪队列,执行队列,阻塞对列,故需要利用对列来实现。最好利用队列类来实现,这样可以充分利用类的继承来简化程序。 队列类的定义如下 class queue public: queue():rear(NULL),front(NULL); queue(); void enqueue( char &item); char dequeue(); void del(char item); void display(); int find(char item); int isempty()return front=NULL; private: queuenode *front,*rear; ; 队列类的析构函数如下 queue:queue() queuenode * p; while(front!=NULL) p=front;front=front-link;delete p; 队列类的成员函数的定义如下: void queue:enqueue(char &item) if(front=NULL) front=rear=new queuenode(item,NULL); else rear=rear-link=new queuenode(item,NULL); char queue:dequeue() queuenode *p=front; char f=p-data; front=front-link; delete p; return f; void queue:display() queuenode *p; p=front; while(p!=NULL) coutdata; p=p-link; coutdata) return 1; break; else w=w-link; goto M; if(w=NULL) return 0; void queue:del( char item) queuenode *q,*b; q=front; while(q-data!=item) b=q; q=q-link; if(q=front) front=front-link; delete q; else if(q=rear) rear=b;rear-link=NULL;delete q; else b-link=q-link; delete q; 五、程序设计流程图六、 源程序清单 源程序如下 #include class queue; class queuenode friend class queue; /*定义队列的友类*/ private: char data; queuenode * link; queuenode (char d=0,queuenode * l=NULL): data(d),link(l) ; class queue /*定义队列类以利于执行就绪*/ /*阻塞队列的继承*/ public: queue():rear(NULL),front(NULL); /*构造函数*/ queue(); void enqueue( char &item); char dequeue(); void del(char item); void display(); int find(char item); int isempty()return front=NULL; /*判断队列是否为空*/ private: queuenode *front,*rear; /*队列的头指针和指向下一结点的指针*/ ; queue:queue() /*定义析构函数*/ queuenode * p; while(front!=NULL) p=front;front=front-link;delete p; void queue:enqueue(char &item) /*定义入队列函数*/ if(front=NULL) front=rear=new queuenode(item,NULL); else rear=rear-link=new queuenode(item,NULL); char queue:dequeue() /*出队列函数*/ queuenode *p=front; char f=p-data;front=front-link; delete p; return f; void queue:display() queuenode *p; p=front; while(p!=NULL) /*如果队列非空输出数据并使指针指向*/ /*下一数据*/ coutdata; p=p-link; coutdata) return 1;break; else w=w-link; goto M; if(w=NULL) return 0; void queue:del( char item) /*删除某值的函数*/ queuenode *q,*b; q=front; while(q-data!=item) b=q; q=q-link; if(q=front) front=front-link; delete q; else if(q=rear) rear=b;rear-link=NULL; delete q; else b-link=q-link; delete q; void main() int n; char a; coutn*进程管理小模拟系统*nendl; queue zhixing,jiuxu,zuse; coutn*注意:*n1.若想结束输入请输入R。n2.本模拟系统进程调度采用的是先来先服务算法输入进程名的顺序即为到达cpu的顺序nendl; char r; r=R; for(int i=0;i+) char e100; cout输入进程名:ei; if(ei!=r) jiuxu.enqueue(ei); /*将输入插入就绪队列*/ else break; A: coutn; if(n=1) if(!zhixing.isempty () cout已经有进程在执行,此操作不能执行n; char w; coutendl; cout如果要继续请输入#如果要退出按其它任意键endl; coutw; if(w=#) goto L; /*无条件转移至L*/ else goto E; else if(!jiuxu.isempty() a=jiuxu.dequeue(); if(a!=r) zhixing.enqueue(a); goto L; else goto L; else if(n=2) if(!zuse.isempty() a=zuse.dequeue (); if(a!=r) jiuxu.enqueue(a); goto L; else goto L; else if(n=3) if(!zhixing.isempty() a=zhixing.dequeue (); if(a!=r) zuse.enqueue(a); goto L; else goto L; else if(n=4) couta; if(zhixing.find (a)|jiuxu.find (a)|zuse.find (a) /*查找所有队列中是否含*/ /*有a若有结束进程a*/ if(zhixing.find(a) zhixing.del(a); else if(jiuxu.find(a) jiuxu.del(a); if(zuse.find(a) zuse.del(a); coutn结束进程成功nendl; goto L; else cout没有此进程endl; goto L; L: if(n=1|n=2|n=3|n=4) /*输出执行就绪阻塞队列*/ cout执行队列endl; zhixing.display(); coutendl; cout就绪队列endl; jiuxu.display();coutendl; cout阻塞队列endl; zuse.display();coutendl; goto A; else if(n=5); else goto A; E:; 七、调试过程中的问题及系统测试情况 1、调试过程 调试时一开始老是出错,尤其是c语言和vc+有区别的地方。比如类的定义后要加分号,而函数的定义则不用。 在调试时,有时候出现警告信息,有时候没有。可能是因为机房和宿舍的编译器的版本不同导致的吧。在调试的过程中,出现的问题不是很多,主要是因为本系统采用的数据结构比较少,而且进程调度算法是先来先服务算法,用程序比较容易实现。若用高响应比优先等算法,估计难度会比这大。 2、系统测试结果进入系统,首先系统会有提示信息,提示信息如下: 按系统的提示输入数据以后,输入结束符按enter键后系统如下图所示:如上图所示,如果我们输入1按Enter键以后结果如下图所示,以此类推,按入其他的数字进行其他操作:八、系统设计总结 通过这次课程设计,使我们对操作系统有了更进一步的认识和了解,要想学好它要重在实践,要通过不断的实践才能更好地学习它,我们也发现我们的好多不足之处,通过学习也有所改进;因为是亲自在做,所以每一步比起学习理论知识更管用多了。在做的过程中,不光是收获本课的知识,也了解了不少计算机的一些我们不太会关注的东西。如什么叫进程,它是如何工作的,为什么会有它的产生呢!平时,我们都知道计算机会莫名其妙的很卡,那是因为什么呢?就是因为进程,是因为我们打开的软件太多了,我们都知道计算机不是同时一起对所有运行界面一起实现,而是它在用很快速的速度对我们操作的那一块出现的执行,这种速度可以让我们感觉到是同时在运作的。作为学习这个专业的学生,我觉得这些认识都是我们最基本的,所以深入学习进程如何管理和工作情况是必须的。再有就是对操作系统的一些系统调用不太了解,还有对操作系统中经常出现的错误也不了解,所以在以后的学习过程中,我们会更加注视实践操作。 在课程设计过程中,收获知识,提高能力的同时,我们也懂得怎么样去制定、实现计划,课程设计是培养学生综合运用所学知识发现提出分析和解决实际问题锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程。随着科学技术发展的日新月异,自从拿到题目到完成整个编程,从理论到实践,可以学到很多很多的东西,同时不仅可以巩固以前所学过的知识,而且学到了很多在书本上没有学到过的知识。通过这次课程设计使我们懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,在设计的过程中发现自己的不足之处,对一些前面学过的知识理解得不够深刻,掌握得不够牢固,在设计中我们遇到了很多编程问题,最后在老师的辛勤指导下,我们慢慢的进入状态,我们做的是一个进程调用的设计,内容包括很多。函数设计也是非常的复杂,所以设计程序一定要仔细,不容一点的马虎。当然也有大问题,关
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二手车销售合同样本
- 公寓空调采购合同样本
- 中介介绍费合同标准文本
- lol职业选手合同样本
- 企业水泥运输合同样本
- 供销合同样本标题
- 个人委托购买公寓合同标准文本
- 2012施工合同样本
- 伞架购销合同样本
- 停息挂账协议合同标准文本
- 校长在高考动员大会上讲话:高考不是独木桥人生处处有航道
- 观赏鱼国际贸易的可持续发展策略
- 2025年浙江纺织服装职业技术学院单招职业适应性测试题库新版
- 《园林微景观设计与制作》课件-项目四 微景观展示
- 2025年河南省安阳市安阳县九年级中考一模数学试题(原卷版+解析版)
- 2025年贵州省交通厅及公路局事业单位历年高频重点模拟试卷提升(共500题附带答案详解)
- 2024年河北省普通高中学业水平选择性考试物理试题含答案
- 大班爬山安全
- 生态农业面源污染治理-深度研究
- 新版《医疗器械经营质量管理规范》(2024)培训试题及答案
- 二零二五年度工业电机维修、安装、调试全方位服务合同2篇
评论
0/150
提交评论