多级反馈队列调度算法的实现.docx
《多级反馈队列调度算法的实现.docx》由会员分享,可在线阅读,更多相关《多级反馈队列调度算法的实现.docx(10页珍藏版)》请在第壹文秘上搜索。
1、学生实习报告课程名称.数据结构与数据处理应用训练题目名称多级反应队列调度算法的实现学生学院计算机与计算科学专业班级学号学生姓名指导教师2012年2月16日多级反应队列调度算法的实现【摘要】多级反应队列调度算法是操作系统中CPU处理机调度算法之一,该算法既能使高优先级的进程任务得到响应又能使短进程任务迅速完成。UNIX操作系统便采取这种算法,而本次试验就是试用C语言模拟某多级反应队列调度算法。本次试验中前三级就绪队列采用时间片轮转法,时间片大小分别为2、4和8,最后一级就绪队列采用FlFO调度,将任务进入多级队列进行模拟,任务从优先级高的队列到优先级地的队列的顺序逐一进入,还用了算法支持抢占式,
2、最后完成模拟,得到各个任务先后完成的顺序,还有得到各个任务的响应时间、离开时间、周转时间。【关健词】队列优先级任务时间1内容与要求【内容】多级反应队列调度算法是操作系统中CPU处理机调度算法之一,该算法既能使高优先级的进程(任务)得到响应又能使短进程(任务)迅速完成。UNiX操作系统便采取这种算法,本次试验就是试用C语言模拟某多级反应队列调度算法,通过输入任务号、到达时间、运行时间,求出任务完成的先后顺序以及各个任务的响应时间、离开时间、周转时间。【要求】多级反应队列调度算法描述:1、该调度算法设置四级就绪队列:前三级就绪队列采用时间片轮转法,时间片大小分别为2、4和8:最后一级就绪队列采用F
3、lFo调度。2,任务在进入待调度的队列等待时,首先进入优先级最高的队列等待3、首先调度优先级高的队列中的任务。假设高优先级中队列中己没有调度的任务,那么调度次优先级队列中的任务,依次类推。4,对于同一个队列中的各个任务,按照队列指定调度方法调度。每次任务调度执行后,假设没有完成任务,就被降到下一个低优先级队列中。5、在低优先级的队列中的任务在运行时,又有新到达的任务,CPU马上分配给新到达的任务。(注:与原来的题目不同,原题是在低优先级的队列中的任务在运行时,又有新到达的任务时,要在运行完这个时间片后,CPl马上分配给新到达的任务,而此题不需要在运行完这个时间片,即正在进行的任务立刻停止,CP
4、U马上分配给新到达的任务)6、为方便实现,时间以1为单位,用整数数据表示;且每个时间点,最多只有一个任务请求效劳(即输入)。2总体设计2.1 算法总体思路:这是建立在一个时间轴上的,即时刻,一个一个时刻(时间点)进行。主函数思路:先初始化所有队列,再输入任务个数,如果输入个数为0,那么重新输入,然后输入各个任务的信息,即任务号、到达时间、运行时间,再当时刻到任务的到达时间时,就创立任务,然后运行任务,时刻自动加1,创立任务与运行任务进行循环,直到所有任务进行完或所有队列为空才跳出循环,最后清空所有队列。功能函数思路:voidcreate(LinkQucuc*x,Jobjob):使任务的己运行时
5、间为0,再使任务进入第一个队列。voidfunction(LinkQueuc*x,inttiming):四个队列从第一个到第四个,即从最高优先级开始,任务在4个队列中逐个进行,根据任务是否为第一次执行,求出响应时间,任务完成时,求出离开时间和周转时间输出信息,在前3个队列,如果任务刚完成一个就绪队列的时间片,就降低优先级,使任务进入下一个队列。2.2 功能模块介绍:voidmain()函数功能:主函数voidInitQueue(LinkQueueiHQ):队列的初始化voidEnQueue(LinkQueueHQ1ElemTypeitem)函数功能:向队列中插入一个元素ElemTypeOutQ
6、ueue(LinkQueuefcHQ)函数功能:从队列中删除一个元素ElemType*PeekQueue(LinkQueueGHQ)函数功能:读取队首元素boolEmptyQueue(LinkQueueHQ)函数功能:检查队列是否为空voidClearQueue(LinkQueuefeHQ)函数功能:去除链队中的所有元素,使之变为空队voidcreate(LinkQueue*x,Jobjob)函数功能:创立任务.voidfunction(LinkQueue*x,int.timing)函数功能:任务运行.2.3 3输入输出输入:任务号到达时间运行时间输出:任务号响应时间离开时间周转时间、2.4文
7、件介绍Inain.cpp:主函数的存放,功能函数的调用。queue,h:队列的各个根本功能函数,任务的创立函数与运行函数。3详细设计3.1 存储结构描述structJobintjobnum;任务号intarrivetime;到达时间intburst;运行时间intretime;响应时间intleavetime;离开时间introundtime;周转时间intruntime;已运行时间;任务的存储结构typedefJobElCmType;任务的类型定义structLNodeElemTypedata;值域1.NOde*nextj链接指针域;structLinkQueue1.NodU*fmnt;/队
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 多级 反馈 队列 调度 算法 实现