处理机。该优先权的变化可描述为: 优先权=(等待时间+要求服务时间)/要求服务时间 由于等待时间加上要求服务时间,就是系统对该作业的响应时间,故该优先权又相当于响应比Rp = 等待时间加要求服务时间/要求服务时间=响应时间/要求服务时间 由上式可以看出: (1)如果作业的等待时间相同,则要求服务的时间愈短,其优先权愈高,因而该算法有利于短作业; (2)当要求服务的时间相同时,作业的优先权决定于其等待时间,因而实现了先来先服务; (3)对于长作业,当其等待时间足够长时,其优先权便可升到很高,从而也可获得处理机。 该算法既照顾了短作业,又考虑了作业到达的先后顺序,也不会使作业长期得不到服务。因此,该算法实现了一种较好的折衷。当然,再利用该算法时,每要进行调度之前,都需先进行响应应比的计算,这会增加系统的开销。 4 方案论证 4.1 概要设计 假设在单道批处理环境下有四个作业JOB1、JOB2、JOB3、JOB4,已知它们进入系统的时间、估计运行时间。分别采用先来先服务(FCFS),最短作业优先(SJF)、响应比高者优先(HRN)的调度算法,计算出作业的平均周转时间和带权的平均周转时间 。 作业 i 的周转时间:Ti=Tci-Tsi 作业的平均周转时间:T= 作业i的带权周转时间:Wi=Ti/Tri 作业的平均带权周转时间:W= 先来先服务调度算法(FCFS):每次调度都是从后备作业队列中,选择一个或多个最先进入该队列的作业,将它们调入内存,为它们分配资源、创建进程,然后放入就绪队列。在进程调度中采用FCFS算法时,这每次调度是从就绪队列中,选择一个最先进入该队列的进程,为之分配处理机,使之投入运行。该进程一直运行到完成或发生某事件阻赛后,才放弃处理机。 短作业(进程)优先调度算法SJ(P)F,是指对短作业或短进程优先调度的算法。它们可分别用于作业调度和进程调度。该调度算法是从后备(就绪)队列中选择一个或若干第 2 页
个估计运行时间最短的作业(进程),将它们调度内存运行。 响应比高者优先(HRN):每次从后备队列中选择一个或若干个估计响应比最高的作业,将它们调入内存运行。 响应比Rp=作业响应时间/运行时间 =作业等待时间+作业运行时间 =1+作业等待时间 每个作业由一个作业控制块JCB表示,JCB可以包含如下信息:作业名、提交时间、所需的运行时间、所需的资源、作业状态、链指针等等。 作业的状态可以是等待W(Wait)、运行R(Run)和完成F(Finish)三种状态之一。每个作业的最初状态总是等待W。 各个等待的作业按照提交时刻的先后次序排队,总是首先调度等待队列中队首的作业。 每个作业完成后要打印该作业的开始运行时刻、完成时刻、周转时间和带权周转时间,这一组作业完成后要计算并打印这组作业的平均周转时间、带权平均周转时间。 4.2 详细设计 4.2.1 程序设计过程中的部分算法 (1)用类C语言定义相关的数据类型 定义头文件: #include mintime=jcb_ready; rear=mintime->link; while(rear!=NULL) if ((rear!=NULL)&&(T>=rear->subtime)&&(mintime->Rp)<(rear->Rp)) { //队尾不空时,作业按运行时间排队 front=mintime; mintime=rear; rear=rear->link; ipmove=1; } else rear=rear->link; if (ipmove==1){ //队首作业完成,改变指针 front->link=mintime->link; mintime->link=jcb_ready; } jcb_ready=mintime; } 4.2.2 主程序流程图 : 计算并打印运行作业i的完成时刻Tc,周转时间Ti,带权周转时间Wi (完成时刻Tc=开始运行时刻+运行时间 周转时间Ti=完成时刻-提交时刻 带权周转时间Wi=周转时间÷运行时间) 第 5 页 调度队首的作业投入运行:(更改队首指针,使作业的状态为R,记住作业开始运行的时刻Tb等) 开 始 初始化所有的JCB 使JCB按作业提交的时刻的先后顺序排队 时间量 T:=0 计算并打印这组作业的平均周转时间及带权平均周转时间 队列为空 ? 更改时间量T的值 (T:=T+作业i的运行时间) 结 束 图1 调度算法流程图 图2 第 6 页 5 运行结果 图3 运行结果 6 心得体会 经过一周的努力,我的课程设计基本完成了,这次课程设计培养了我耐心、慎密、全面地考虑问题的能力,从而加快了问题解决的速度、提高了个人的工作效率,以及锻炼围绕问题在短时间内得以解决的顽强意志。 在编写程序的过程中,我的能力得到了提高,同时养成了科学、严谨的作风和习惯。为此我要感谢信息学院开设了这门操作系统课程设计,为我们提供了进一步学习算法、操作系统和巩固C语言程序计设这个平台并。同时还要感谢对同一题目进行攻关的同学们给予的帮助,没他们的帮助可能有很多问题我个人不能进行很好的解决。在此我对他们帮助给予衷心的感谢。 7 附录 #include \"stdio.h\" #include { front=mintime; mintime=rear; rear=rear->link; ipmove=1; } else rear=rear->link; if (ipmove==1){ front->link=mintime->link; mintime->link=jcb_ready; } jcb_ready=mintime; } void input() /* 建立作业控制块函数*/ { int i,num; printf(\"\\n 请输入作业数:?\"); scanf(\"%d\ for(i=0;i free(j); } void running(JCB* jr) /* 建立作业就绪函数(作业运行时间到,置就绪状态*/ { if (T>=jr->subtime) jr->wt.Tb=T; else jr->wt.Tb=jr->subtime; jr->wt.Tc=jr->wt.Tb+jr->runtime; jr->wt.Ti=jr->wt.Tc-jr->subtime; jr->wt.Wi=jr->wt.Ti/jr->runtime; T=jr->wt.Tc; } int main() /*主函数*/ { int select=0,len,h=0; float sumTi=0,sumWi=0; input(); len=space(); printf(\"\\n\1.FCFS 2.SJF 3.HRN\\n\\n请选择作业调度算法:?\"); scanf(\"%d\ while((len!=0)&&(jcb_ready!=NULL)) { h++; printf(\"\\n 执行第%d个作业 \\n\ j=jcb_ready; jcb_ready=j->link; j->link=NULL; j->state='R'; running(j); sumTi+=j->wt.Ti; sumWi+=j->wt.Wi; check(select); if (select==2&&h 第 13 页
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- baijiahaobaidu.com 版权所有 湘ICP备2023023988号-9
违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务