(完整版)操作系统短作业优先调度算法汇总,推荐文档_第1页
(完整版)操作系统短作业优先调度算法汇总,推荐文档_第2页
(完整版)操作系统短作业优先调度算法汇总,推荐文档_第3页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

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

文档简介

1、课 程设 计采用短作业优先调度算法调度程序学 号: 姓 名: 专 业: 指导老师: 日 期 : 目录一、实验题目3二、课程设计的目的3三、设计内容3四、设计要求3五、主要数据结构及其说明4六、程序运行结果5七、流程图7八、源程序文件9九、实验体会13十、参考文献1313摘要在多道程序环境下,主存中有着多个进程,其数目往往多于处理机数目。这就要求系统能按某种算法,动态地把处理机分配给就绪队列中的一个进程,使之执行。分配处理机的任务是由处理机调度程序完成的。由于处理机是最重要的计算机资源,提高处理机的利用率及改善系统性能(吞吐量、响应时间),在很大程度上取决于处理机调度性能的好坏,因而,处理机调度

2、便成为操作系统设计的中心问题之一。在多道程序系统中,一个作业被提交后必须经过处理机调度后, 方能获得处理机执行。对于批量型作业而言,通常需要经历作业调度和进程调度两个过程后方能获得处理机。作业调度是对成批进入系统的用户作业,根据作业控制块的信息,按一定的策略选取若干个作业使它们可以去获得处理器运行的一项工作。而对每个用户来说总希望自己的作业的周转时间是最小的,短作业优先(sjf)便是其中一种调度方法。 本次课程设计主要是模拟短作业优先(sjf)调度算法。一、实验题目采用短作业优先算法的的进程调度程序二、课程设计的目的l 操作系统课程设计是计算机专业重要的教学环节,它为学生提供了一个既动手又动脑

3、,将课本上的理论知识和实际有机的结合一起,独立分析和解决实际问题的机会。l 进一步巩固和复习操作系统的基础知识。l 培养学生结构化程序、模块化程序设计的方法和能力。l 提高学生调试程序的技巧和软件设计的能力。l 提高学生分析问题、解决问题以及综合利用 c 语言进行程序设计的能力。三、设计内容设计并实现一个采用短作业优先算的进程调度算法演示程序四、设计要求1. 每一个进程有一个 pcb,其内容可以根据具体情况设定。2. 进程数、进入内存时间、要求服务时间、优先级等均可以在界面上设定3. 可读取样例数据(要求存放在外部文件中)进行进程数、进入内存时间、时间片长度、进程优先级的初始化4. 可以在运行

4、中显示各进程的状态:就绪、执行 (由于不要求设置互斥资源与进程间同步关系,故只有两种状态)5. 采用可视化界面,可在进程调度过程中随时暂停调度,查看当前进程的状态以及相应的阻塞队列五、主要数据结构及其说明算法的基本概念和原理:本次课程设计主要是采用短作业优先算法进程的进程调度过程。短作业优先调度算法,是指对短作业或短进程优先调度的算法。他们可以分别用于作业调度和进程调度,短作业优先的调度算法是从后备队列中选择一个或若干个估计运行时间最短的作业,将他们调入内存运行。而短进程优先调度算法则是从就绪队列中选出一个估计运行时间最短的进程,将处理机分配给他,使它立即执行并一直执行到完成,或发生某事件而被

5、阻塞放弃处理机时再度重新调度。本程序采用了非抢占式短作业优先调度。而非抢占式这种方式,一旦把处理机分配给某进程后,便让该进程一直执行,直至该进程完成或发生某事件而被阻塞时,才再把处理机分配给其它进程,决不允许某进程抢占已经分配出去的处理机。这种调度方式的优点是实现简单,系统开销小, 适用于大多数的批处理系统环境。但它难以满足紧急任务的要求立即执行, 因而可能造成难以预料的后果。因此,在要求比较严格的实时系统中,不宜采用这种调度方式。本课程设计主要是在满足要求多道单处理机的情况下进行短作业的优先调度。算法的简要说明:短作业(进程)优先调度算法 sj(p)f,是指对短作业或短进程优先调度的算法。它

6、们可以分别用于作业调度和进程调度。短作业优先(sjf)的调度算法是从后备队列中选择一个或若干个估计运行时间最短的作业,将它们调入内存运行。而短进程(spf)调度算法则是从就绪队列中选出一个估计运行时间最短的进程,将处理机分配给它,使它立即执行并一直执行到完成,或发生某事件而被阻塞放弃处理机再重新调度。优点是 sj(p)f 调度算法能有效地降低作业(进程)的平均等待时间,提高系统吞吐量。缺点是该算法对长作业不利;完全未考虑作业的紧迫程度,因而不能保证紧迫性作业(进程)长期不被调度;由于作业(进程)的长短只是根据用户所提供的估计执行时间而定的,而用户又可能会有意或无意地缩短其作业的估计运行时间,致

7、使该算法不一定能真正做到短作业游戏那调度。该程序定义了一个进程数据块(struct process_),该数据块有进程名(name)、到达时间(arrivetime)、服务时间(servicetime)、开始执行时间(starttime)、完成时间(finishtime)、周转时间(zztime)、带权周转时间(dqzztime)、执行顺序(order)。用到的公式有:完成时间=到达时间+服务时间;周转时间=完成时间+到达时间; 带权周转时间=周转时间/服务时间;(第一次执行的进程的完成时间=该进程的 到达时间;下一个进程的开始执行时间=上一个进程的完成时间)。运行进程的顺序需要对进程的到达时

8、间和服务时间进行比较。如果某一进程是从 0 时刻到达的,那么首先执行该进程;之后就比较进程的服务时间,谁的服务时间短就先执行谁(如果服务时间相同则看它们的到达时间,到达时间短的先执行);如果到达时间和服务时间相同,则按先来先服务算法执行。六、程序运行结果1 进入操作界面如下2 输入进程的信息3 各时刻进程的状态4 进程信息5 平均带权周转时间界面七、流程图本次课程设计主要是通过比较各个进程的优先级以及各进程所需 要占用的 cpu 时间来确定哪个作业优先运行,短作业优先调度算法除了能保证优先级更高的作业优先运行外,还能使相同优先级的前提下, 所需 cpu 时间最短的那个作业优先运行,次外,本次课

9、程设计还增加了阻塞时间和被阻塞时间来对个进程的运行加以控制。 此次课程设计的总体流程图如下:r结束输出最后信息:output()开 始输入进程的个数:numsort()输入进程的信息:namestarttimeservicetime队列中是否只有一个进程?ny执行时间处理函数:time()执行判断函数:run()八、源程序文件#include #define maxnum 100 using namespace std; struct process_structintnumber;/进程编号char namemaxnum;/进程名称intarrivaltime;/到达时间intservice

10、time;/开始运行时间intfinishtime;/运行结束时间intwholetime;/运行时间 int run_flag;/调度标志int order;/运行次序doubleweightwholetime;/周转时间double averagewt_fcfs,averagewt_sjf;/平均周转时间 double averagewwt_fcfs,averagewwt_sjf;/平均带权周转时间processmaxnum;int n;/实际进程个数int sjf();/短作业优先int sjf()/短作业优先算法 int temp_time=0;/当期那时间int i=0,j;int

11、number_schedul,temp_counter;/进程编号,当前已执行进程个数float run_time;run_time=processi.wholetime; j=1;while(jn)&(processi.arrivaltime=processj.arrivaltime)/判断是否有两个进程同时到达if(processj.wholetimeprocessi.wholetime) j+;run_time=processi.wholetime; i=j;/查找下一个被调度的进程/对找到的下一个被调度的进程求相应的参数number_schedul=i;processnumber_sc

12、hedul.servicetime=processnumber_schedul.arrivaltime; processnumber_schedul.finishtime=processnumber_schedul.servicetime+processnumber_schedul.wholetime; processnumber_schedul.run_flag=1; temp_time=processnumber_schedul.finishtime; processnumber_schedul.order=1; temp_counter=1;while(temp_countern)for

13、(j=0;jn;j+)if(processj.arrivaltime=temp_time)&(!processj.run_flag)run_time=processj.wholetime; number_schedul=j;break;for(j=0;jn;j+)if(processj.arrivaltime=temp_time)&(!processj.run_flag) if(processj.wholetimerun_time)run_time=processj.wholetime; number_schedul=j;/查找下一个被调度的进程/对找到的下一个被调度的进程求相应的参数proc

14、essnumber_schedul.servicetime=temp_time;processnumber_schedul.finishtime=processnumber_schedul.servicetime+p rocessnumber_schedul.wholetime;processnumber_schedul.run_flag=1; temp_time=processnumber_schedul.finishtime; temp_counter+; processnumber_schedul.order=temp_counter;return 0;int pinput();/进程参

15、数输入int poutput();/调度结果输出void main()int option;printf(*主菜单*n);printf(*1使用短作业优先*n);printf(*0退出*n);printf(*n);/system(cls); system(color 1f);scanf(%d,&option); switch(option)case 0:printf(运行结束。n); break;case 1:printf(对进程用短作业优先调度。nn); pinput();sjf();poutput(); break;int pinput()/进程参数输入int i;printf(请输入进程

16、个数:n); scanf(%d,&n); for(i=0;in;i+)printf(*n); printf(请输入一个进程:n,i+1);printf(请输入进程名称:n);scanf(%s,processi.name); printf(请输入到达时间:n);scanf(%d,&processi.arrivaltime); printf(请输入服务时间:n); scanf(%d,&processi.wholetime); processi.servicetime=0; processi.finishtime=0; processi.weightwholetime=0; processi.ord

17、er=0; processi.run_flag=0;system(cls);return 0;int poutput()/调度结果输出int i;float turn_round_time=0,f1,w=0;printf(进程名称 到达 t 运行 t 开始运行 t 结束 t 执行顺序 周转 t带权周转 tn);for(i=0;in;i+)processi.weightwholetime=processi.finishtime-processi.arrivaltime; f1=processi.weightwholetime/processi.wholetime; turn_round_time

18、+=processi.weightwholetime;w+=f1;printf(时刻%d :,processi.servicetime,processi.name);printf(%s%d%d%d%d%d%f%fn,processi.name,processi.arrivaltime,processi.wholetime,processi.serv icetime,processi.finishtime,processi.order,processi.weightwholetime,f1);printf(average_turn_round_timer=%fn,turn_round_time/

19、n); printf(weight_average_turn_round_timer=%fn,w/n);return 0;九、实验体会通过本次课程设计,使我对计算机操作系统短作业优先调度算法这一节的知识有了更深的了解 。短作业优先调度算法易于实现,并且效率很高,但是短作业只考虑到短作业的利益,而不顾长作业,这样就可能会使得长作业 一直处于等待状态而不能运行。所以,短作业优先算法适用于系统中短作业 较多的情况。此外,通过本次实验,进一步巩固和复习操作系统的基础知识, 更进一步的了解了结构化模块化程序设计的方法,提高了调试程序的技巧, 提高了自己的动手能力我对操作系统中的作业调度模拟和短作业优先算

20、法有 了更深的认识。并且发现,只看课本上的知识远远不够,只一味学习也根本 没用,必须要动手亲自实践,才能真正掌握所学的东西。虽然在这次课程 设计过程中,我们也遇到了很多问题,但我们都能保持一个良好的心态,不 急不躁,并且能通过请教老师,与同学们积极讨论,查看课外资料,反复实 验,反复检查,将问题一个个解答,并最终成功的完成本次课程设计。课程 设计结束了,在这次的课程设计中不仅检验了我所学习的知识,也培养了我 如何去做一件事情,又如何完成一件事情的能力。通过模拟进程的调度问题,更加深了我对于操作系统理论的理解,在自己的动手操作过程中,能够体会成功的喜悦和遇到问题自己解决的能力, 对于我来说是一次提高,让自己多多的在实践中可以加深对理论的理解,也让我明白了以后应该如何更好,更高效的学习,在以后,我会更加努力。总之,本次课程设计让我们学到了很多东西,包括课本上的和课外的, 是一个非常有意义的课程设计。十、参考文献1) 宗大华,宗涛,陈吉人著 操作系统北京:人民邮电出版社,20092) 李爱华,程磊著面相对象程序设计(c+语言) 北京: 清华大学出版社,20103) 宋晓宇 , windows 操作系统核心编程实验教程 中国铁道出版社4) 张丽芬 刘利雄 王金玉编著 操作系统实验教程清华大学出版社“”“”at the

温馨提示

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

评论

0/150

提交评论