作业
最高响应比优先算法:
作业 提交时刻 运行时刻 开始时刻 完成时刻
1 10:00 2:00 10:00 12:00
2 10:10 1:00 12:25 3:15
3 10:25 0:25 12:25 2:00
作业1周转时间 2:00, 带权周转时间 2:00/2:00
作业2周转时间 3:15, 带权周转时间 3:15/1:00
作业3周转时间 2:00, 带权周转时间 2:00/0:25
平均周转时间T=(2:00+3:15+2:00)/3
平均带权周转时间W=(2:00/2:00+3:15/1:00+2:00/0:25)/3
p119, 22
进程 开始时间 结束时间 所需时间 等待时间
1 0 4 9 0
2 4 8 4 3
3 8 12 8 6
4 12 16 10 9
1 16 20 5 12
3 20 24 4 12
4 24 28 6 8
1 28 29 1 8
4 29 31 2 1
进程1 周转时间 33, 带权周转时间33/9
进程2 周转时间 10, 带权周转时间10/4
进程3 周转时间 22, 带权周转时间22/8
进程4 周转时间 29, 带权周转时间29/10
平均周转时间 23.5
带权平均周转时间 9.05
3,现设定采用三级反馈队列调度算法,三个队列分别为0、1和2,对应时间片为2、4、8。现有四个进程A、B、C、D,到达时刻分别为0、5、7、12,执行时间分别为7、4、13、2。请写出整个进程调度过程,包括每个时间段,执行的进程,执行后进程状态,各个队列内进程的变化。
CPU |
|
A2 |
A4 |
B2 |
C2 |
C4 |
D2 |
A8 |
B4 |
C8 |
0-2 |
A7 |
|
B4 |
C7 |
|
D12 |
|
|
|
|
1~4 |
|
|
A5 |
B2 |
C5 |
|
D2 |
|
|
|
2~8 |
|
|
|
|
|
|
|
|
|
|
时间 |
0 |
2 |
6 |
8 |
10 |
14 |
16 |
21 |
23 |
28 |
先来先服务(FCFS)调度算法
FCFS调度算法的特点是算法简单,但效率低;对长作业比较有利,但对短作业不利(相对SJF和高响应比);有利于CPU繁忙型作业,而不利于I/O繁忙型作业。
短作业优先(SJF)调度算法
短作业(进程)优先调度算法是指对短作业(进程)优先调度的算法。短作业优先(SJF)调度算法是从后备队列中选择一个或若干个估计运行时间最短的作业,将它们调入内存运行。而短进程优先(SPF)调度算法,则是从就绪队列中选择一个估计运行时间最短的进程,将处理机分配给它,使之立即执行,直到完成或发生某事件而阻塞时,才释放处理机。,对长作业把比较不利,短作业比较有利
优先级调度算法
优先级调度算法又称优先权调度算法,该算法既可以用于作业调度,也可以用于进程调度,该算法中的优先级用于描述作业运行的紧迫程度。
高响应比优先调度算法
高响应比优先调度算法主要用于作业调度,该算法是对FCFS调度算法和SJF调度算法的一种综合平衡,同时考虑每个作业的等待时间和估计的运行时间。在每次进行作业调度时,先计算后备作业队列中每个作业的响应比,从中选出响应比最高的作业投入运行。
对于长作业,作业的响应比可以随等待时间的增加而提高,当其等待时间足够长时,其响应比便可升到很高,从而也可获得处理机。克服了饥饿状态,兼顾了长作业。
时间片轮转调度算法
时间片轮转调度算法主要适用于分时系统。在这种算法中,系统将所有就绪进程按到达时间的先后次序排成一个队列,进程调度程序总是选择就绪队列中第一个进程执行,即先来先服务的原则,但仅能运行一个时间片,如100ms。在使用完一个时间片后,即使进程并未完成其运行,它也必须释放出(被剥夺)处理机给下一个就绪的进程,而被剥夺的进程返回到就绪队列的末尾重新排队,等候再次运行。