时间片轮转课程设计分析解析_第1页
时间片轮转课程设计分析解析_第2页
时间片轮转课程设计分析解析_第3页
时间片轮转课程设计分析解析_第4页
时间片轮转课程设计分析解析_第5页
已阅读5页,还剩20页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、武汉理工大学华夏学院 课程设计报告书 课程名称: 操作系统原理 题 目 : 时间片轮转调度算法 系 名: 信息工程系 专业班级: 姓 名: 学 号: 指导教师 : 司晓梅2015 年 6 月 26 日武汉理工大学华夏学院信息工程系课程设计任务书课程名称: 操作系统原理课程设计 指导教师: 司晓梅 班级名称:计算机 1131-2 开课系、教研室: 自动化与计算机一、课程设计目的与任务操作系统课程设计是 操作系统原理 课程的后续实践课程, 旨在通过一周的实践训练, 加深学生对理论课程中操作系统概念, 原理和方法的理解, 加强学生综合运用操作系统原理、 Linux 系统、 C 语言程序设计技术进行实

2、际问题处理的能力,进一步提高学生进行分析问题 和解决问题的能力,包含系统分析、系统设计、系统实现和系统测试的能力。学生将在指导老师的指导下,完成从需求分析,系统设计,编码到测试的全过程。二、课程设计的内容与基本要求1、课程设计题目时间片轮转进程调度模拟算法的实现2、课程设计内容用 c/c+ 语言实现时间片轮转的进程调度模拟算法。要求:1 至少要有 5 个以上进程2 进程被调度占有 CPU 后,打印出该进程正在运行的相关信息 提示 : 时间片轮转调度算法中,进程调度程序总是选择就绪队列中的第一个进程,也就是说按照先来 先服务原则调度,但一旦进程占用 处理机 则仅使用一个时间片。在使用完一个时间片

3、后,进程还没 有完成其运行,它必须释放出处理机给下一个就绪的进程,而被抢占的进程返回到就绪队列的末尾 重新排队等待再次运行。1)进程运行时,只打印出相关提示信息,同时将它已经运行的时间片加1 就可以了。2)为进程设计出 PCB 结构。 PCB 结构所包含的内容,有进程名、进程所需运行时间、已运行 时间和进程的状态以及指针的信息等。3 、设计报告撰写格式要求:1 设计题目与要求 2 设计思想3 系统结构 4 数据结构的说明和模块的算法流程图5 使用说明书(即用户手册):内容包含如何登录、退出、读、写等操作说明6 运行结果和结果分析(其中包括实验的检查结果、程序的运行情况)7 自我评价与总结 8

4、附录:程序清单,注意加注释(包括关键字、方法、变量 等),在每个模块前加注释;三、课程设计步骤及时间进度和场地安排本课程设计将安排在第 17 周, 现代教育技术中心。具体安排如下:时间设计内容第一天下发任务书,学生查阅资料第二天系统设计和原型开发第三天 -第四天系统功能实现第五天系统调试、测试、打包和验收课程设计集中时间安排:周次星期一星期二星期三星期四星期五第 17 周第 2-3 节第 2-3 节第 2-3 节第 2-3 节第 3-6 节地点现教现教现教现教现教四、课程设计考核及评分标准课程设计考核将综合考虑学生的系统设计方案、 运行结果、 课程设计报告书的质量、 态 度、考勤、答辩情况等各

5、因素。具体评分标准如下:1)设计方案正确,具有可行性、创新性;30分2)系统开发效果较好;20分3)设计报告规范、课程设计报告质量高、参考文献充分20 分4)课程设计答辩时,问题回答正确;20分5)态度认真、刻苦钻研、遵守纪律;10分按上述五项分别记分后求和,总分按五级制记载最后成绩。优秀(10090分),良好(8089 分),中等(7079 分),及格( 60 69分), 不及格( 059 分)1、实验概叙1.1 实验目的弄明白时间片轮转的工作流程和原理, 通过实验让自己更明白切身体会的深! 时间片轮 转主要是解决处理机调度进程时的优化! 正确理解提高处理机的利用率及改善系统性能在很 大程度

6、上取决于处理机调度性能的好坏, 在操作系统中调度的实质是一种资源分配, 调度算 法是指根据系统的资源分配策略规定的资源分配算法, 对不同的系统和系统目标, 应采用不 的调度算法。 在多道程序或多任务系统中, 系统同时处于就绪状态的进程有若干个。 也就是 说能运行的进程数远远大于处理机个数。 为了使系统中的各进程能有条不紊地运行, 必须选 择某种调度策略,以选择一进程占用处理机。通过本实验, 加深对处理机调度的理解。 弄明白时间片轮转的工作流程和原理, 通过实 验让自己更明白切身体会的深!1.2 实验原理基于时间片轮转调度算法思想用 C 语言编程实现1.3 实验环境(使用的软件)Visual C

7、+6.02、实验思想及内容2.1 设计思想按照时间片工作原理 : 时间片轮转的原则是系统将所有的就绪进程按照先来先服务的原 则排成一个队列, 每次调度时, 把 CPU分配对手进程, 并令其执行一个时间片, 当执行完时, 有一个计时器发出时钟中断请求, 该进程停止, 并被送到就绪队列的末尾, 然后再把处理机 分配就绪队列的队列进程,同时也让它执行一个时间片 !2.2 实验原理基于时间片轮转调度算法思想用 C 语言编程实现2.3 系统结构设计 时间片大小固定,由用户输入。进程个数由用户输入。 每个进程用一个 PCB表示。 PCB包括进程名,到达时间,运行时间,剩余时间,进程状 态,链接指针。其中,

8、进程名,到达时间和运行时间由用户输入,剩余时间的初值等于运行时间。为简单起见,进程状态设为三种:就绪,运行和完成。链接指针指向下一个进程的PCB;按照进程到达的先后顺序排成一个队列。设置一个队头指针指向队列中第一个进 程, 并设置一个队尾指针指向队列中的最后一个进程;执行调度时,先选择队首的第一个进程运行。另外设置一个指向当前运行进程的指针; 由于本实验是模拟实验, 所以对选中进程并不实际启动运行, 而只是执行: 被选中进程 的状态置为运行态; 被选中进程的剩余时间减去时间片大小; 按照队列的顺序依次输出每个 进程的进程名,到达时间,运行时间,剩余时间,进程状态。用这三个操作来模拟进程的一 次

9、运行;进程运行一次后, 以后的调度则将当前指针依次下移一个位置, 指向下一个进程, 即调 整当前运行指针,以指示应运行进程。同时还应判断该进程的剩余时间是否为0。如果不为0,则等待下一轮的运行;如果该进程的剩余时间为0,则将该进程的状态置为完成态,并退出队列;若处于就绪态的进程不为空,则重复第 d 步和第 e 步直到所有进程都运行完为止。2.4 算法流程图开始初始化 PCB ,输入进程信各进程按优先数从高到低排列结束就绪队 列为 空?就绪队列首进程投入运行运行进程已占 用 CPU 时间 达到所需运行 时间时间片到,运行进程已占用 CUP 时间 +1进程完成撤销该进程使运行进程优先数 -1,把运

10、行 进程插入优先队列。2.5 实验过程(实验步骤、记录、数据、分析)测试用例 1:屏幕显示: Please input the process name, arrive time and run time 输入:1 2 12 3 13 2 24 1 25 1 1测试数据 2:1 1 22 3 23 1 24 3 15 1 1 测试数据 3:1 1 12 2 23 2 14 1 25 1 13、结论(结果)3.1 测试数据 1 的运行结果(截图):3.2 测试数据 2 的运行结果(截图):Pl pa*ore nunhp*:5Pleaseinput the process nanearrive t

11、ine and run tine:IFor exanple: 12 11122 3 23 124 3 15 11Pleaseinput the slice:1| M M M M M X M MX M X M X M X M X M X M X M MX M M M 菟 M M M Xnamearriverunreststate5110running3122ready1122ready4311*eaiy2322readynamearriverunreststate3I21running1122ready4311ready232nanearriveG 杓Xrunreststate4121ready

12、1110running3211ready2222readyXMMXMMXMxxxxxxxxInanearriverunveststatek=121ready14、源程序代码:#include stdio.h#include stdlib.h struct studint name;int arrive;int run;int rest;char * state;struct stud * next; /*pcb 结构体 */struct stud * create()int a,i;struct stud * head, * rear, *p,*q,*t; /* 定义各个指针 */ head=

13、rear =NULL;printf( Please input the process number:);scanf( %d, &a);printf( nPlease input the process name,arrive time and run time:nFor example: 1 2 1n);for (i =0;i name,&p- arrive, &p- run); p - rest =p- run;p - state =ready ;if (rear =NULL) /* 只有一个进程 */ head=p; p- next =NULL; rear =p;else t =NULL

14、; q=head;while (q &q- arrive arrive)t =q; q =q- next; if (q =head) /* 指向头进程的下一个进程 */ p- next =head; head =p; else if (t =rear) /* 运行到最后一个进程 */ rear - next =p; p - next =NULL; rear =p; else t - next =p;p- next =q; return head;void output( struct stud * head)struct stud *p,*t, *r;int slice; printf( Pl

15、ease input the slice:);scanf( %d, &slice); while (head != NULL) r =p=head; while (p != NULL)t =head;p- rest =p- rest - slice;/* 剩余时间减去时间片 */p- state =running ;if (p - rest rest =0;);printf( n *n printf( nametarrivetruntresttstaten );while (t != NULL) printf( %dt%dt%dt%dt%sn ,t - name,t - arrive,t -

16、run,t - rest,t - state);t =t - next;if (p - rest =0) /* 判断是否删除结点 */ if (p =head) head=p- next; free(p);p=head; /* 删除头结点 */else r - next =p- next;p=r - next; r=p; elser=p;p - state =ready ; /* 如果不删除头结点指针指向下一个,状态变为准备 */p =p- next;void main()struct stud * head; head =create(); output(head) ;5、小结5.1实验中产

17、生的错误及原因分析:5.1.1 程序运行不下去:错误分析:链表初始化排序过程中:指针 p=Null 时,不能执行 q-arrive 等命 令;错误解决方法:将while (q - arrive arrive &q)t =q;q =q- next; 改为: while (q &q- arrive arrive)t =q;q =q- next; 5.1.2 进程运行时间大于时间片时,程序进入死循环 : 当进程所需时间等于时间片时,运行结果正确:进程运行时间大于时间片时,程序进入死循环:错误分析: 进程所需剩余时间计算错误; 错误修改: 将while (p != NULL) t =head;p- rest =p-run- slice; p- state =running ;修改为: while (p != NULL) t =head;p- rest =p-rest- slice; p- state =running ;5.2实验的体会及收获:通过这次试验,我对 处理机的调度算法 - 基于时间片轮转调度算法思想有了更深的 理解 ;另外使我对链表的知识有了更深的理解,而且锻炼了我的思维能力,使我能更全面地 思考问题,以后还需要多做些这方面的练习。5.3 实验还需改进之处:为考虑进程所需时间小于时间片大小的情况, 如:进程运行完一次时

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论