先来先服务和短作业优先调度算法

调度算法的概念

在OS中调度的实质是一种资源分配,因而调度算法是指:根据系统的资源分配策略所规定的资源分配算法。

对于不同的系统和系统目标,通常采用不同的调度算法:例如,在批处理系统中为照顾为数众多的短作业,应采用短作业优先的调度算法;又如在分时系统中,为了保证系统具有合理的响应时间,应采用轮转法进行调度。

目前存在的多种调度算法中,有的算法适用于作业调度,有的算法适用于进程调度;但有些算法作业调度和进程调度都可以采用。

 

几个运算概念

进程从进入外存的后备队列就已经算是进入了系统,之后经历进入内存,使用CPU,执行完毕/进入阻塞。

周转时间T = 在后备队列的时间t1 + 在内存的时间t2 + 使用CPU的时间t3 + 阻塞的时间t4

平均周转时间 = (T1 + T2 + T3 +... + Tn) / n

带权周转时间 = T / t3

平均带权周转时间 = (T1 / t3 + T2 / t3 + T3 / t3 +... + Tn / t3) / n

 

先来先服务调度算法(FCFS)

是一种最简单的调度算法,既可用于作业调度,也可用于进程调度。

当在作业调度中采用FCFS算法时,每次调度都是从后备作业队列中,选择一个或多个最先进入该队列的作业,将它们调入内存,为它们分配资源、创建进程,然后放入就绪队列;

进程调度采用FCFS算法时,则每次调度是从就绪队列中选择一个最先进入该队列的进程,为之分配处理机,使之运行。

FCFS算法比较有利于长作业(进程),而不利于短作业(进程)。

 

例题1

下表列出了A、B、C、D四个作业分别到达系统的时间、要求服务的时间、开始执行的时间及各自的完成时间,并计算出各自的周转时间和带权周转时间。

 

(1)在先来先服务调度算法的基础上使用非抢占原则:

(2)在先来先服务调度算法的基础上使用抢占原则:由于该算法首要遵循的就是先来先服务,所以会严格按照先后顺序执行,FCFS                   算法在非抢占和抢占原则上是相同的。

从表格得到:C作业的带权周转时间高达100;而D作业的带权周转时间仅1.99;可以认为C作业并没有频繁使用CPU而是请求外设,被阻塞,结束了时间片。D作业是一直频繁的使用CPU。

所以可以总结:FCFS调度算法有利于CPU繁忙型的作业(如通常的科学计算),而不利于I/O繁忙型的作业(指CPU进行处理时,需频繁的请求I/O)。也就是说,FCFS算法比较有利于长作业(进程),而不利于短作业(进程)。

 

短作业(进程)优先算法(SJ(P)F)

短作业优先(SJF)的调度算法,是从后备队列中选择一个或若干个估计运行时间最短的作业,将它们调入内存运行。

短进程优先(SPF)调度算法,是从就绪队列中选出一估计运行时间最短的进程,将处理机分配给它,使它立即执行并一直执行到完成,或发生某事件而被阻塞放弃处理机时,再重新调度。

 

例题2

采用SJF算法后,不论是平均周转时间还是平均带权周转时间,都较FCFS调度算法有较明显的改善,尤其是对短作业D。而平均带权周转时间从2.8降到了2.1。这说明SJF调度算法能有效的降低作业的平均等待事件,提高系统吞吐量。

从表中仍能看出,长作业的带权周转时间边长了,所以该算法对长作业不利。该算法也没有考虑作业紧迫程度,不能保证急迫性作被及时处理。最重要的是,作业的长短是事先估计出来的,包含主观因素,不一定能真正做到短作业优先。

 

  • 28
    点赞
  • 151
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值