进程调度程序设计报告源代码

进程调度程序设计报告源代码

ID:32510096

大小:375.71 KB

页数:19页

时间:2019-02-10

进程调度程序设计报告源代码_第1页
进程调度程序设计报告源代码_第2页
进程调度程序设计报告源代码_第3页
进程调度程序设计报告源代码_第4页
进程调度程序设计报告源代码_第5页
资源描述:

《进程调度程序设计报告源代码》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、成绩课程设计报告题目进程调度程序设计课程名称操作系统课程设计院部名称计算机工程学院专业计算机科学与技术班级13计算机科学与技术(单)(1)学生姓名周敏健学号1305201013课程设计地点A104课程设计学时20学时指导教师何健金陵科技学院教务处制19目录摘要3一、课程设计的目的和要求4二、系统需求分析4三、总体设计5四、详细设计6五、测试、调试过程9六、结论与体会11七、参考文献12附录:源程序1219课程设计课题进程调度程序设计摘要在多道系统中,对批处理作业需要进行作业调度。作业调度是在资源满足的条件下,将处于就绪状态的作业调入内存,同时生成与作业相对应的进程,并未这些进程提供所

2、需要的资源。进程调度需要根据进程控制块(PCB)中的信息,检查系统是否满足进程的资源需求。只有在满足进程的资源需求的情况下,系统才能进行进程调度。下面是几种常见的作业调度算法:先来先服务(FCFS)、优先算法、轮换算法、短作业优先算法以及最高响应比优先法等,本文将对前两种算法进行详细的介绍。关键词:进程调度,优先级,FCFS,PCB,作业,资源19一、课程设计的目的和要求1、目的进程调度是处理机管理的核心内容。本设计要求用C语言编写和调试一个简单的进程调度程序。通过设计本可以加深理解有关进程控制块、进程队列的概念,并体会和了解最高优先数优先的调度算法(即把处理机分配给优先数最高的进程

3、)和先来先服务算法的具体实施办法。2、要求1)进程调度算法:采用最高优先数优先的调度算法(即把处理机分配给优先数最高的进程)和先来先服务算法。  2)每个进程有一个进程控制块(PCB)表示。进程控制块可以包含如下信息:进程名、优先数、到达时间、需要运行时间、已用CPU时间、进程状态等等。  3)进程的优先数及需要的运行时间可以事先人为地指定(也可以由随机数产生)。进程的到达时间为进程输入的时间。进程的运行时间以时间片为单位进行计算。  4)每个进程的状态可以是就绪W(Wait)、运行R(Run)、或完成F(Finish)三种状态之一。  5)就绪进程获得CPU后都只能运行一个时间片。

4、用已占用CPU时间加1来表示。如果运行一个时间片后,进程的已占用CPU时间已达到所需要的运行时间,则撤消该进程,如果运行一个时间片后进程的已占用CPU时间还未达所需要的运行时间,也就是进程还需要继续运行,此时应将进程的优先数减1(即降低一级),然后把它插入就绪队列等待CPU。  6)每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的PCB,以便进行检查。  7)重复以上过程,直到所要进程都完成为止。二、系统需求分析编写一个模拟进程调度的程序,将每个进程抽象成一个进程控制块PCB,PCB用一个结构体描述。采用两种不同的调度算法来实现功能,主要有如下几大功能模块组成。(1)创

5、建优先数PCB模块19用循环来实现对每个进程的进程名、进程优先数(随机分配)以及所需时间的录入。将进程队列存放到就绪队列等待执行。(1)优先数调度算法模块从优先级最高(就绪队列的第一个进程)的开始执行,每执行一次优先数减1,并重新放入就绪队列进行排序,对排序完的继续运行直到所有进程都结束。(2)FCFS创建PCB模块对N个进程的信息进行输入:进程名、到达时间、需要时间等。每输入一个进程,按进程的到达时间进行排序,记下前驱和后继的方法。(3)FCFS调度算法模块当系统时间与第一个进程到达时间一致时,将进程状态置为Run,直到这个进程执行完,再判断下个进程的到达时间,若系统时间大于下个进

6、程的到达时间,即上个进程的结束时间就是下个进程的开始时间,反之就等待系统时间。进程结束后放入完成队列。(4)主函数及菜单显示由主菜单进入显示界面,进行算法选择。三、总体设计进程是程序在处理机上的执行过程。进程存在的标识是进程控制块(PCB),所谓系统创建一个进程,就是由系统为某个程序设置一个PCB,用于对该进程进行控制和管理。进程任务完成,由系统收回其PCB,该进程便消亡。每个进程可有三个状态:运行状态、就绪状态和完成状态。因此设计三个链队列,finish为完成队列的头指针,wait为就绪队列的头指针。因为每一时刻,CPU只能运行一个进程,所以运行队列只有一个run指针指向当前运行的

7、进程。考虑到处理的方便,将它们设为全局变量。总体结构框架图:19优先数算法界面FCFS算法开始四、详细设计(1)优先数调度算法优先调度算法要为每一个进程设一个优先数,它总是把处理机给就绪队列中具有最高优先权的进程。常用的算法有静态优先权法和动态优先权法。本程序采用了动态优先权法,使进程的优先权随时间而改变。初始的进程优先数取决于进程运行所需的时间,时间大,则优先数低,所以采取了将进程优先数定位最大的那个进程,随着进程的运行优先数进行调整,每次运行时都是从就

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。