采用高响应比算法的进程调度程序.docx
《采用高响应比算法的进程调度程序.docx》由会员分享,可在线阅读,更多相关《采用高响应比算法的进程调度程序.docx(3页珍藏版)》请在冰豆网上搜索。
![采用高响应比算法的进程调度程序.docx](https://file1.bdocx.com/fileroot1/2023-3/28/b17eddbb-c186-4b44-84ff-f909d0fabca1/b17eddbb-c186-4b44-84ff-f909d0fabca11.gif)
采用高响应比算法的进程调度程序
采用高响应比算法的进程调度程序
操作系统课程设计 采用高响应比算法的进程调度程序 学 院 专 业 学生姓名 学 号 指导教师姓名 目录 一、实验题目..........................错误!
未定义书签。
二、课程设计的目的....................错误!
未定义书签。
三、设计内容..........................错误!
未定义书签。
四、程序功能分析......................错误!
未定义书签。
五、实验原理...........................................2 六、设计要求...........................................6 七、程序总设计流程图...................................6 八、程序运行结果及分析................错误!
未定义书签。
九、小结..............................错误!
未定义书签。
十、源代码.............................................9 2 一、实验题目 采用高响应比算法的进程调度程序 二、课程设计的目的:
了一个既动手又动脑,将课本上的理论知识和实际有机的结合一起,独立分析和解决实际问题的机会。
同时提高了同学的动手能力和团队合作精神,充分体现了合作的重要性。
编写程序,采用高响应比作业调度算法,首先要确定作业控制块的内容和组成方式;然后完成作业调度,最后编写主函数,对所做工作进行测试。
(1)进一步巩固和复习操作系统的基础知识。
(2)培养学生结构化程序、模块化程序设计的方法和能力。
(3)提高学生调试程序的技巧和软件设计的能力. (4)提高学生分析问题、解决问题以及综合利用C语言进行程序设计的能力。
操作系统课程设计是计算机专业重要的教学环节,它为学生提供 三、设计内容:
设计并实现一个采用高响应比算法的进程调度演示程序,响应比R定义 如下:
RWT/T1W/T其中T为该作业估计需要的执行时间,为作业在后备状态队列中的等待时W间。
每当要进行作业调度时,系统计算每个作业的响应比,选择其中R最大者投入执行。
这样,即使是长作业,随着它等待时间的增加,W/T也就随着增加,也就有机会获得调度执行。
这种算法是介于FCFS和SJF之间的一种折中算法。
于长作业也有机会投入运行,在同一时间内处理的作业数显然要少于SJF法,从而采用HRRN方式时其吞吐量将小于采用SJF法时的吞吐量。
另外,于每次调度前要计算响应比,系统开销也要相应增加。
四、程序功能分析 在批处理系统中,短作业优先算法是一种比较好的算法,其主要的不足之处是长作业的运行得不到保证。
于是我们想到了一种办法解决这个问题,就是引用动态优先权、并使作业的优先级随着等待时间的增加而以速率a提高,长作业在等待一定的时间后,必然有机会分配到处理机,这样长作业也得到了运行。
此可见:
如果作业的等待时间相同,则要求服务的时间越短,其优先权越高,因此该算法有利于短作业。
当要求服务的时间相同时,作业的优先权取决与其等待的时间,等待时间越长,其优先权越高,因而它实现的是先来先服务。
对于长作业,作业的优先权可以随等待时间的增加而提高,当其等待时间足够长时,其优先级便可升到很高,从而也可以获得处理机。
五、实验原理 高响应比优先调度算法既考虑作业的执行时间也考虑作业的等待时间,综 3 合了先来先服务和最短作业优先两种算法的特点。
该算法中的响应比是指作业等待时间与运行比值,响应比公式定义如下:
响应比=/要求服务时间,即RR=/s=1+w/s,因此响应比一定是大于1的。
某系统有3个作业,系统确定它们在全部到达后,再开始采用响应比高者优先的调度算法,则它们的调度顺序是什么?
各自的周转时间是什么?
作业号提交时间运行时间123
(1)如果都到达再算的话,等待时间=最后一个的提交时间-该作业到达的时刻 1:
=2:
=3:
0 所以响应比为\\要求服务时间=等待时间/要求服务时间+1 1:
/+1=2:
/+1=3:
1 所以2先运行,2从开始运行到结束;再以时刻算响应比:
1:
()/+1=3:
()/1+1= 所以2执行完后1开始执行,从执行到结束最后一个是3:
从开始执行到结束
(2)如果不是都到达后才运行,那么在时只有作业1到达,所以先运行作业+=到的时候作业1完成,此时作业2和3都已到达所以计算其响应比\\要求服务时间=等待时间/要求服务时间+1 作业2:
/+1=作业3:
/+1= 所以先运行作业+=到运行作业+=到结束 4 高响应比函数执行过程流程图:
开始 当前作业为依编号找到的第一个还未执行的作业 当前作业是最后一个作业 当前作业和下一个还没执行的作业比较 当前作业在上次作业被执行完之前到达 同时到达 当前作业取较早达到当前作业取较当前作业取相且响应比较早到达的一个应比较高的一个高的一个 返回这一次要执行的作业 5
六、设计要求:
1.每一个进程有一个PCB,其内容可以根据具体情况设定。
2.进程数、进入内存时间、要求服务时间、优先级等均可以在界面上设定3.可读取样例数据进行进程数、进入内存时间、时 间片长度、进程优先级的初始化 4.可以在运行中显示各进程的状态:
就绪、执行 5.采用可视化界面,可在进程调度过程中随时暂停调度,查看当前进程的状态 以及相应的阻塞队列 6.有性能比较功能,可比较同一组数据在不同调度算法下的平均周转时间7.具有一定的数据容错性 七、程序总设计流程图 读取进程判断进程是否进入内存是否对响应比排序高的进程先运行等待结束 6 八、程序运行结果及分析 输入两个进程a、b,在高响应比调度算法下的进程运行情况及各进程的性能分析如下:
输入四个进程A、B、C、D在高响应比算法下的调度顺序,通过响应比的比较,判断进程调度的次序,提高的进程的调度性能。
且高响应比调度算法适合于批处理操作。
7 九、结论 通过本次实验对用高响应比算法的优先调度算法有了更深入的理解和掌握,进一步巩固和复习操作系统的基础知识,更进一步的了解了结构化模块化程序设计的方法,提高了调试程序的技巧。
同时使我们对进程调度模拟设计的各种算法有了更进一步的理解,在编写程序时所遇到的问题让我有了对操作系统更深层次的理解和掌握,知道操作系统这门课程实在是很重要的一门课程。
8 十、源代码 #includeinte=0;structP{ charname[10];floatarrtime;floatsertime;floatstartime;floatfinishtime;floatzztime;floatdqzztime;floatpower;}; Pa[100]; voidinput(P*,int);voidmove(P*,int);voidwork(P*,int);voidGxyb(P*,int);voidrate(P*,float); voidmain(){ intN; printf(\***********欢迎进入高响应比调度算法模拟界面********** \\n\ printf(\请输入进程的个数:
\scanf(\input(a,N);Gxyb(a,N);} voidinput(P*p,intN){ inti; for(i=0;i 9 } voidwork(P*p,intN){ for(inti=0;ip[j].arrtime) { Ptemp; temp=p[i]; p[i]=p[j]; p[j]=temp; } else if(p[i].arrtime==p[j].arrtime) {if(p[i].sertime>p[j].sertime) {Ptemp; temp=p[i]; p[i]=p[j]; p[j]=temp; } }} voidrate(P*p,intN){++e; for(intm=N-1;m>=e;m--)if(p[m].arrtime p[m].power=(p[e-1].finishtime-p[m].arrtime+p[m].sertime)/p[m].sertime; for(inti=e;i voidmove(P*p,intN) 10
{ intk; printf(\高响应比调度的顺序:
\printf(\for(k=1;k printf(\ printf(\各进程运行的详细信息如下:
\\n\ printf(\名称到达时间服务时间开始时间结束时间周转时间带权周转时间\\n\ for(k=0;k printf(\rtime,p[k].sertime,p[k].startime,p[k].finishtime,p[k].zztime,p[k].dqzztime);}} voiddeal(P*p,intN){ intk; for(k=0;k for(k=0;k 11 }} voidGxyb(P*p,intN){inti=0,n; floatarrtime=0,sertime=0,startime=0,finishtime=0,zztime=0,dqzztime=0;printf(\各进程的运行情况如下:
\\n\ work(p,N); for(intm=0;m 12 } else {p[m].finishtime=p[m].arrtime+p[m].sertime;printf(\在第%-.0f时刻进程信息\\n\printf(\正在运行\\n\for(n=m+1;n } for(intl=0;l move(p,N); 致谢 感谢老师您的指导!
13