调度算法学习小结(附例题)

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

原理:每次调度是从就绪队列中选择最先进入的进程,为之分配处理机,使之执行,该进程一直执行到完成或发生阻塞事件为止。

二、短进程优先(SJF)调度算法

原理:从就绪队列中选出一估计运行时间最短的进程,将处理机分配给它,使它立即执行并一直执行到完成或发生阻塞事件为止,再重新调度。

三、最短剩余时间优先调度算法

原理:总是选择剩余运行时间最短的进程执行,如果新到的进程比正在执行的进程运行时间更短,则当前进程被停止转而运行新到的进程。

四、高优先权(FPF)优先调度算法

非抢占式优先权算法原理:系统把处理机分配给就绪队列中优先权最高的进程后执行到结束或发生阻塞事件为止,再重新分配给另一优先权最高的进程。

抢占式优先权算法原理:某进程执行期间,只要出现了更高优先权的进程,调度程序立即停止当前进程,重新分配给新到的优先权最高的进程。

五、高响应比优先调度算法

优先权=(等待时间+要求服务时间)/(要求服务时间)

六、基于时间片轮转调度算法(RR算法)

原理:就绪进程按先来先服务原则分配给队首进程,执行一个时间片。若时间片用完时此进程还未执行结束,则将它送往就绪队列末尾,执行下个进程。若时间片内进程已经完成,则将它从就绪队列中删除(即进程结束),再调度就绪队列中队首的进程运行并启动一个新的时间片

七、多级反馈队列调度算法

原理:设置多个就绪队列,各个队列优先级不同,各个队列中进程执行时间片的大小也各不相同。队列优先级越高执行时间片越小。

必备公式:周转时间=完成时间-到达时间    带权周转时间=周转时间/服务时间

【应用举例1】

假设在单道批处理环境下有四个作业,已知它们进入系统的时间、估计运行时间:

作业进入时间估计运行时间(分钟)
JOB18:00120
JOB28:5050
JOB39:0010
JOB49:5020

应用FCFS、SJF和高响应比优先作业调度算法,分别计算出作业的平均周转时间和带权的平均周转时间。

FCFS:

作业到达时间开始执行时间运行时间(分钟)结束时间
JOB18:008:0012010:00
JOB28:5010:005010:50
JOB39:0010:501011:00
JOB49:5011:002011:20

平均周转时间=\frac{120+120+120+90}{4}=112.5分钟

带权平均周转时间=\frac{1+2.4+12+4.5}{4}=4.975分钟

SJF:

作业到达时间开始执行时间运行时间(分钟)结束时间
JOB18:008:0012010:00
JOB28:5010:305011:20
JOB39:0010:001010:10
JOB49:5010:102010:30

平均周转时间=\frac{120+150+70+40}{4}=95分钟

带权平均周转时间=\frac{1+3+7+2}{4}=3.25分钟

高响应比优先:

作业到达时间开始执行时间运行时间(分钟)结束时间优先权
JOB18:008:0012010:00
JOB28:50502.4
JOB39:0010:001010:107
JOB49:50201.5

基于JOB1结束时刻

作业到达时间开始执行时间运行时间(分钟)结束时间优先权
JOB28:5010:105011:002.6
JOB49:5011:002011:202

基于JOB3结束时刻

平均周转时间=\frac{120+130+70+90}{4}=102.5分钟

带权平均周转时间=\frac{1+2.6+7+4.5}{4}=3.775分钟

【应用举例2】

进程A、B、C、D、E分别需要运行的时间、到达时间如下表所示,如果采用RR算法的时间片分别为1和4时,请给出各个进程的带权周转时间。

进程名ABCDE
到达时间01234
服务时间43424

求解:画队列分析+画图辅助

时间片为1:

队列(左为就绪队列,右为执行进程):

\rightarrow A

A\rightarrow B

BC\rightarrow A

ADB\rightarrow C

CEAD\rightarrow B

BCEA\rightarrow D

DBCE\rightarrow A

ADBC\rightarrow E

EADB\rightarrow C

CEAD\rightarrow B(B执行结束)

CEA\rightarrow D(D执行结束)

CE\rightarrow A(A执行结束)

C\rightarrow E

E\rightarrow C

C\rightarrow E

E\rightarrow C(C执行结束)

\rightarrow E(E执行结束)

运行时刻图(草图见谅):

综上,结果如下:

完成时间1210161117
周转时间12914813
带权周转时间333.543.25

时间片为4:

队列和图此处省略···

完成时间47111317
周转时间4691013
带权周转时间122.2553.25

部分反思:关于高响应比优先调度算法,此处的优先权计算公式只是确认优先权方法的其中一种,且其为不抢占式算法,但是要注意计算时刻应该以什么为基准~多复习五态图~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值