- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
淮海工学院计算机工程学院
实验报告书
课程名: 《操作系统原理》
题 目: 进程调度
班 级:
学 号:
姓 名:
实验报告要求
1.目的与要求
进程是操作系统最重要的概念之一,进程调度是操作系统内核的重要功能,本实验要求用C语言编写一个进程调度模拟程序,使用优先级或时间片轮转法实现进程调度。本实验可加深对进程调度算法的理解。
2.实验内容
1、设计有5个进程并发执行的模拟调度程序,每个程序由一个PCB表示。
2、模拟调度程序可任选两种调度算法之一实现。
3、程序执行中应能在屏幕上显示出各进程的状态变化,以便于观察调度的整个过程。
3.实验环境
Turbo C 2.0/3.0或VC++6.0
4.实验说明
1、优先级算法说明
(1)PCB的结构:
Id Span Used Need Satus Next 优先级算法中,设PCB的结构如右图所示,其中各数据项的含义如下:
Id:进程标识符号,取值1—5。
Prior:优先级,随机产生,范围1—5。
Used:目前已占用的CPU时间数,初值为0;当该进程被调用执行时,
每执行一个时间片,Used加1。
Need:进程尚需的CPU时间数,初值表示该进程需要运行的总时间,取值范围为5—10。并随机产生,每运行一个时间片need减1;need为0则进程结束。
Status:进程状态R(运行),J(就绪),F(完成);初始时都处于就绪状态。
Next:指向就绪队列中下一个进程的PCB的指针。
(2)初始状态及就绪队列组织:
5个进程初始都处于就绪状态,进程标识1—5,used初值都为0。各进程的优先级随机产生,范围1—5。处于就绪状态的进程,用队列加以组织,队列按优先级由高到低依次排列,队首指针设为head,队尾指针设为tail。
(3)调度原则以及运行时间的处理:
正在执行的进程每执行一个时间片,其优先级减1(允许优先级为负)。进程调度将在以下情况发生:当正在运行的程序其优先级小于就绪队列队首进程的优先级时。程序中进程的运行时间以逻辑时间片为单位。
2、时间片轮转算法说明
(1)PCB的结构(如下图所示):
轮转法中,设PCB的结构如右图所示,其中各数据项的含义如下:
Id Span Used Need Satus Next Id:进程标识符号,取值1—5。
Span:在某一轮中,分配给先运行进程的时间片数,取值1—3。
Used:现运行进程在本轮执行过程已用的时间片数。
Need:进程尚需的CPU时间数,初值表示该进程需要运行的总时间,
取值范围5—10。并随机产生,每运行一个时间片need减1;
need为0则进程结束。
Status:进程状态R(运行),J(就绪),F(完成);初始时所有进程处于就绪状态。
Next:指向就绪队列中下一个进程的PCB的指针。
(2)初始状态及就绪队列组织:
Span、Used在每轮开始时赋初值,Used初值值为0,Span初值要求随机产生。
(3)调度原则:
当一个进程被调度程序执行时,每经过一个时间片,Need减1,Used加1,如果Need为0,表示该进程结束,如果Need不为0,并且Used小于本轮Span值,则该进程可继续运行,若Need不为0,且Used等于Span值,则该进程本轮运行时间已到,应调度下一个队首进程运行。
实验步骤
理解本实验中关于两种调度算法的说明。
根据调度算法的说明,画出相应的程序流程图。
FCFS流程图简介:
如图:
RR流程图简介:
如图
按照程序流程图,用C语言编程并实现。
先来先来服务调度算法--------FCFS
选择4个进程,然后选择FCFS,如图所示进行和等待还有阻塞时间一看便知。
选择等待就绪出现页面:如图所示
选择阻塞出现的页面:如图
时间片轮转法-------RR
选择进程4个,然后选择时间片轮转算法:如下图所示
选择等待就绪出现的页面如图所示:
选择阻塞时出现以下的页面:如图所示
4.分析与思考
1.逻辑时间片该如何实现?
系统将所有的就绪进程按先来先服务算法的原则,排成一个队列,每次调度时,系统把处理机分配给队列首进程,并让其执行一个时间片。当执行的时间片用完时,由一个计时器发出时钟中断请求,调度程序根据这个请求停止该进程的运行,将它送到就绪队列的末尾,再把处理机分给就绪队列中新的队首进程,同时让它也执行一个时间片。
2.如果不使用指针操作,是否也可以使用数组实现进程就绪队列的组织?
可以
5.结果分析与实验体会
通过对两种不同算法的数据结构的实现,深入
文档评论(0)