第三章 处理机调度与死锁
第三章 处理机调度与死锁
3.1 处理机调度的基本概念
3.2 调度算法
3.3 实时调度
3.4 多处理机系统中的调度
3.5 产生死锁的原因和必要条件
3.6 预防死锁的方法
3.7 死锁的检测与解除
第三章 处理机调度与死锁
3.1 处理机调度的基本概念
3.1.1 高级、中级和低级调度
1,高级调度 (High Scheduling)
在每次执行作业调度时, 都须做出以下两个决定 。
1) 接纳多少个作业
2) 接纳哪些作业
第三章 处理机调度与死锁
2,低级调度 (Low Level Scheduling)
1) 非抢占方式 (Non-preemptive Mode)
在采用非抢占调度方式时, 可能引起进程调度的因素可
归结为这样几个,① 正在执行的进程执行完毕, 或因发生
某事件而不能再继续执行; ② 执行中的进程因提出 I/O请求
而暂停执行; ③ 在进程通信或同步过程中执行了某种原语
操作, 如 P操作 (wait操作 ),Block原语, Wakeup原语等 。 这
种调度方式的优点是实现简单, 系统开销小, 适用于大多数
的批处理系统环境 。 但它难以满足紧急任务的要求 ——立即
执行, 因而可能造成难以预料的后果 。 显然, 在要求比较严
格的实时系统中, 不宜采用这种调度方式 。
第三章 处理机调度与死锁
2) 抢占方式 (Preemptive Mode)
(1) 优先权原则。
(2) 短作业 (进程 )优先原则。
(3) 时间片原则。
第三章 处理机调度与死锁
3,中级调度 (Intermediate-Level Scheduling)
中级调度又称中程调度 (Medium-Term Scheduling)。 引
入中级调度的主要目的, 是为了提高内存利用率和系统吞
吐量 。 为此, 应使那些暂时不能运行的进程不再占用宝贵
的内存资源, 而将它们调至外存上去等待, 把此时的进程
状态称为就绪驻外存状态或挂起状态 。 当这些进程重又具
备运行条件, 且内存又稍有空闲时, 由中级调度来决定把
外存上的哪些又具备运行条件的就绪进程, 重新调入内存,
并修改其状态为就绪状态, 挂在就绪队列上等待进程调度 。
第三章 处理机调度与死锁
3.1.2 调度队列模型
1,仅有进程调度的调度队列模型
图 3 - 1 仅具有进程调度的调度队列模型
就 绪 队 列
阻 塞 队 列
进程调度
C P U
进程完成
等待事件
交互用户




时间片完
第三章 处理机调度与死锁
2,具有高级和低级调度的调度队列模型
图 3-2 具有高、低两级调度的调度队列模型
就 绪 队 列
进程调度
C P U
进程完成
等待事件 1
作业
调度
事件 1 出现
时间片完
等待事件 2
事件 2 出现
?
?
等待事件 n
事件 n 出现
后 备 队 列
? ?
第三章 处理机调度与死锁
(1) 就绪队列的形式。
(2) 设置多个阻塞队列。
图 3-2 示出了具有高, 低两级调度的调度队列模型 。
该模型与上一模型的主要区别在于如下两个方面 。
第三章 处理机调度与死锁
3,同时具有三级调度的调度队列模型
图 3-3 具有三级调度时的调度队列模型
就绪队列
进程调度
C P U
就绪,挂起队列
中级调度
阻塞,挂起队列
阻塞队列
等待事件
进程完成
时间片完作业调度
交互型作业
后备队列
批量作业
挂起
事件出现




第三章 处理机调度与死锁
3.1.3 选择调度方式和调度算法的若干准则
1,面向用户的准则
(1) 周转时间短。
可把平均周转时间描述为:
??
?
??
?? ?
?
i
i
iTnT
1
1
?
?
?
?
?
?? ?
?
n
i Si
i
T
T
n
W
1
1
作业的周转时间 T与系统为它提供服务的时间 TS之比, 即
W=T/TS,称为带权周转时间, 而平均带权周转时间则可表
示为,
第三章 处理机调度与死锁
(2) 响应时间快。
(3) 截止时间的保证。
(4) 优先权准则。
第三章 处理机调度与死锁
2,
(1) 系统吞吐量高。
(2) 处理机利用率好。
(3) 各类资源的平衡利用。
第三章 处理机调度与死锁
3.2 调 度 算 法
3.2.1 先来先服务和短作业 (进程 )优先调度算法
1,先来先服务调度算法
第三章 处理机调度与死锁
图 3-4 FCFS和 SJF调度算法的性能
第三章 处理机调度与死锁
2,短作业 (进程 )优先调度算法
短作业 (进程 )优先调度算法 SJ(P)F,是指对短作业或
短进程优先调度的算法 。 它们可以分别用于作业调度和
进程调度 。 短作业优先 (SJF)的调度算法, 是从后备队列
中选择一个或若干个估计运行时间最短的作业, 将它们
调入内存运行 。 而短进程优先 (SPF)调度算法, 则是从就
绪队列中选出一估计运行时间最短的进程, 将处理机分
配给它, 使它立即执行并一直执行到完成, 或发生某事
件而被阻塞放弃处理机时, 再重新调度 。
第三章 处理机调度与死锁
SJ(P)F
(1) 该算法对长作业不利, 如作业 C的周转时间由 10增
至 16,其带权周转时间由 2增至 3.1。 更严重的是, 如果有
一长作业 (进程 )进入系统的后备队列 (就绪队列 ),由于调度
程序总是优先调度那些 (即使是后进来的 )短作业 (进程 ),将
导致长作业 (进程 )长期不被调度 。
(2) 该算法完全未考虑作业的紧迫程度, 因而不能保证
紧迫性作业 (进程 )会被及时处理 。
(3) 由于作业 (进程 )的长短只是根据用户所提供的估计
执行时间而定的, 而用户又可能会有意或无意地缩短其作
业的估计运行时间, 致使该算法不一定能真正做到短作业
优先调度 。
第三章 处理机调度与死锁
3.2.2 高优先权优先调度算法
1,优先权调度算法的类型
1) 非抢占式优先权算法
在这种方式下, 系统一旦把处理机分配给就绪队列中
优先权最高的进程后, 该进程便一直执行下去, 直至完成;
或因发生某事件使该进程放弃处理机时, 系统方可再将处
理机重新分配给另一优先权最高的进程 。 这种调度算法主
要用于批处理系统中;也可用于某些对实时性要求不严的
实时系统中 。
第三章 处理机调度与死锁
2)
在这种方式下, 系统同样是把处理机分配给优先权最高
的进程, 使之执行 。 但在其执行期间, 只要又出现了另一个
其优先权更高的进程, 进程调度程序就立即停止当前进程 (原
优先权最高的进程 )的执行, 重新将处理机分配给新到的优先
权最高的进程 。 因此, 在采用这种调度算法时, 是每当系统
中出现一个新的就绪进程 i时, 就将其优先权 Pi与正在执行的
进程 j的优先权 Pj进行比较 。 如果 Pi≤Pj,原进程 Pj便继续执行;
但如果是 Pi> Pj,则立即停止 Pj的执行, 做进程切换, 使 i进程
投入执行 。 显然, 这种抢占式的优先权调度算法, 能更好地
满足紧迫作业的要求, 故而常用于要求比较严格的实时系统
中, 以及对性能要求较高的批处理和分时系统中 。
第三章 处理机调度与死锁
2,优先权的类型
1)
静态优先权是在创建进程时确定的, 且在进程的整个
运行期间保持不变 。 一般地, 优先权是利用某一范围内的
一个整数来表示的, 例如, 0~7或 0~255中的某一整数,
又把该整数称为优先数 。 只是具体用法各异:有的系统用
,0”表示最高优先权, 当数值愈大时, 其优先权愈低;而
有的系统恰恰相反 。
第三章 处理机调度与死锁
(1) 进程类型。
(2) 进程对资源的需求。
(3) 用户要求。
第三章 处理机调度与死锁
2)
动态优先权是指, 在创建进程时所赋予的优先权, 是可
以随进程的推进或随其等待时间的增加而改变的, 以便获得
更好的调度性能 。 例如, 我们可以规定, 在就绪队列中的进
程, 随其等待时间的增长, 其优先权以速率 a提高 。 若所有的
进程都具有相同的优先权初值, 则显然是最先进入就绪队列
的进程, 将因其动态优先权变得最高而优先获得处理机, 此
即 FCFS算法 。 若所有的就绪进程具有各不相同的优先权初值,
那么, 对于优先权初值低的进程, 在等待了足够的时间后,
其优先权便可能升为最高, 从而可以获得处理机 。 当采用抢
占式优先权调度算法时, 如果再规定当前进程的优先权以速
率 b下降, 则可防止一个长作业长期地垄断处理机 。
第三章 处理机调度与死锁
3,高响应比优先调度算法
要求服务时间
要求服务时间等待时间优先权 ??
优先权的变化规律可描述为:
由于等待时间与服务时间之和, 就是系统对该作业的响应
时间, 故该优先权又相当于响应比 RP。 据此, 又可表示为:
要求服务时间
响应时间
要求服务时间
要求服务时间等待时间优先权 ???
第三章 处理机调度与死锁
(1) 如果作业的等待时间相同, 则要求服务的时间愈
短, 其优先权愈高, 因而该算法有利于短作业 。
(2) 当要求服务的时间相同时, 作业的优先权决定于
其等待时间, 等待时间愈长, 其优先权愈高, 因而它实
现的是先来先服务 。
(3) 对于长作业, 作业的优先级可以随等待时间的增
加而提高, 当其等待时间足够长时, 其优先级便可升到
很高, 从而也可获得处理机 。
第三章 处理机调度与死锁
3.2.3 基于时间片的轮转调度算法
1.
在早期的时间片轮转法中, 系统将所有的就绪进程按先
来先服务的原则, 排成一个队列, 每次调度时, 把 CPU分配
给队首进程, 并令其执行一个时间片 。 时间片的大小从几
ms到几百 ms。 当执行的时间片用完时, 由一个计时器发出
时钟中断请求, 调度程序便据此信号来停止该进程的执行,
并将它送往就绪队列的末尾;然后, 再把处理机分配给就绪
队列中新的队首进程, 同时也让它执行一个时间片 。 这样就
可以保证就绪队列中的所有进程, 在一给定的时间内, 均能
获得一时间片的处理机执行时间 。
第三章 处理机调度与死锁
2,多级反馈队列调度算法
(1) 应设置多个就绪队列, 并为各个队列赋予不同的优
先级 。 第一个队列的优先级最高, 第二个队列次之, 其余
各队列的优先权逐个降低 。 该算法赋予各个队列中进程执
行时间片的大小也各不相同, 在优先权愈高的队列中, 为
每个进程所规定的执行时间片就愈小 。 例如, 第二个队列
的时间片要比第一个队列的时间片长一倍, ……,第 i+1个队
列的时间片要比第 i个队列的时间片长一倍 。 图 3-5 是多级
反馈队列算法的示意 。
第三章 处理机调度与死锁
图 3-5 多级反馈队列调度算法
就绪队列 1
就绪队列 2
就绪队列 3
就绪队列 n
S
1
S
2
S
3
至 C P U
至 C P U
至 C P U
至 C P U
( 时间片,S
1
< S
2
< S
3
)
第三章 处理机调度与死锁
(2) 当一个新进程进入内存后, 首先将它放入第一队列
的末尾, 按 FCFS原则排队等待调度 。 当轮到该进程执行时,
如它能在该时间片内完成, 便可准备撤离系统;如果它在
一个时间片结束时尚未完成, 调度程序便将该进程转入第
二队列的末尾, 再同样地按 FCFS原则等待调度执行;如果
它在第二队列中运行一个时间片后仍未完成, 再依次将它
放入第三队列, ……,如此下去, 当一个长作业 (进程 )从第一
队列依次降到第 n队列后, 在第 n队列中便采取按时间片轮
转的方式运行 。
第三章 处理机调度与死锁
(3) 仅当第一队列空闲时, 调度程序才调度第二队列
中的进程运行; 仅当第 1~(i-1) 队列均空时, 才会调度第 i
队列中的进程运行 。 如果处理机正在第 i队列中为某进程
服务时, 又有新进程进入优先权较高的队列 (第 1~(i-1)中
的任何一个队列 ),则此时新进程将抢占正在运行进程的
处理机, 即由调度程序把正在运行的进程放回到第 i队列
的末尾, 把处理机分配给新到的高优先权进程 。
第三章 处理机调度与死锁
3,多级反馈队列调度算法的性能
(1) 终端型作业用户 。
(2) 短批处理作业用户 。
(3) 长批处理作业用户 。
第三章 处理机调度与死锁
3.3 实 时 调 度
3.3.1 实现实时调度的基本条件
1,提供必要的信息
(1) 就绪时间。
(2) 开始截止时间和完成截止时间。
(3) 处理时间。
(4) 资源要求。
(5) 优先级。
第三章 处理机调度与死锁
2,系统处理能力强
在实时系统中, 通常都有着多个实时任务 。 若处理机的
处理能力不够强, 则有可能因处理机忙不过来而使某些实时
任务不能得到及时处理, 从而导致发生难以预料的后果 。
假定系统中有 m个周期性的硬实时任务, 它们的处理时间可
表示为 Ci,周期时间表示为 Pi,则在单处理机情况下, 必须
满足下面的限制条件:
?
?
?
m
i i
i
P
C
1
1
第三章 处理机调度与死锁
系统才是可调度的 。 假如系统中有 6个硬实时任务, 它
们的周期时间都是 50 ms,而每次的处理时间为 10 ms,则
不难算出, 此时是不能满足上式的, 因而系统是不可调度
的 。
解决的方法是提高系统的处理能力, 其途径有二:其一
仍是采用单处理机系统, 但须增强其处理能力, 以显著地
减少对每一个任务的处理时间;其二是采用多处理机系统 。
假定系统中的处理机数为 N,则应将上述的限制条件改为:
?
?
?
m
i i
i N
P
C
1
第三章 处理机调度与死锁
3,采用抢占式调度机制
当一个优先权更高的任务到达时, 允许将当前任务暂时挂
起, 而令高优先权任务立即投入运行, 这样便可满足该硬实时
任务对截止时间的要求 。 但这种调度机制比较复杂 。
对于一些小的实时系统, 如果能预知任务的开始截止时间,
则对实时任务的调度可采用非抢占调度机制, 以简化调度程序
和对任务调度时所花费的系统开销 。 但在设计这种调度机制时,
应使所有的实时任务都比较小, 并在执行完关键性程序和临界
区后, 能及时地将自己阻塞起来, 以便释放出处理机, 供调
度程序去调度那种开始截止时间即将到达的任务 。
第三章 处理机调度与死锁
4,具有快速切换机制
(1) 对外部中断的快速响应能力 。 为使在紧迫的外部
事件请求中断时系统能及时响应, 要求系统具有快速硬件
中断机构, 还应使禁止中断的时间间隔尽量短, 以免耽
误时机 (其它紧迫任务 )。
(2) 快速的任务分派能力 。 在完成任务调度后, 便应
进行任务切换 。 为了提高分派程序进行任务切换时的速度,
应使系统中的每个运行功能单位适当的小, 以减少任务切
换的时间开销 。
第三章 处理机调度与死锁
3.3.2 实时调度算法的分类
1,非抢占式调度算法
(1) 非抢占式轮转调度算法。
(2) 非抢占式优先调度算法。
第三章 处理机调度与死锁
2,抢占式调度算法
(1) 基于时钟中断的抢占式优先权调度算法。
(2) 立即抢占 (Immediate Preemption)的优先权调度算法。
( a ) 非抢占轮转调度
当前进程 实时进程
实时进程请求调度
实时进程枪占当前
进程,并立即执行
( d ) 立即抢占的优先权调度
调度时间
进程 1 进程 2
实时进程要求调度
进程 n 实时进程
调度实时进程运行
( b ) 非抢占优先权调度
当前进程 实时进程
实时进程请求调度 当前进程运行完成
调度时间
当前进程
实时进程请求调度 时钟中断到来时
调度时间
( c ) 基于时钟中断抢占的优先权抢占调度
调度时间
实时进程
图 3-6 实时进程调度
第三章 处理机调度与死锁
3.3.3 常用的几种实时调度算法
1,最早截止时间优先即 EDF(Earliest Deadline First)算法
图 3-7 EDF算法用于非抢占调度方式
1 3 4 2
开始截止时间
任务执行
任务到达
1 2 3 4
1 3 4 2
t
第三章 处理机调度与死锁
2,最低松弛度优先即 LLF(Least Laxity First)算法
该算法是根据任务紧急 (或松弛 )的程度, 来确定任务的优
先级 。 任务的紧急程度愈高, 为该任务所赋予的优先级就愈
高, 以使之优先执行 。 例如, 一个任务在 200ms时必须完成,
而它本身所需的运行时间就有 100ms,因此, 调度程序必须在
100 ms之前调度执行, 该任务的紧急程度 (松弛程度 )为 100 ms。
又如, 另一任务在 400 ms时必须完成, 它本身需要运行 150
ms,则其松弛程度为 250 ms。 在实现该算法时要求系统中有
一个按松弛度排序的实时任务就绪队列, 松弛度最低的任务
排在队列最前面, 调度程序总是选择就绪队列中的队首任务
执行 。 该算法主要用于可抢占调度方式中 。 假如在一个实时
系统中, 有两个周期性实时任务 A和 B,任务 A要求每 20 ms执
行一次, 执行时间为 10 ms;任务 B只要求每 50 ms执行一次,
执行时间为 25 ms。
第三章 处理机调度与死锁
图 3-8 A和 B任务每次必须完成的时间
A
1
A
2
A
3
A
4
A
5
A
6
A
7
A
8
20 40 60 80 1 0 0 1 2 0 1 4 0 1 6 0
B
1
B
2
B
3
t
0
第三章 处理机调度与死锁
在刚开始时 (t1=0),A1必须在 20ms时完成, 而它本身运
行又需 10 ms,可算出 A1的松弛度为 10ms; B1必须在 50ms
时完成, 而它本身运行就需 25 ms,可算出 B1的松弛度为 25
ms,故调度程序应先调度 A1执行 。 在 t2=10 ms时, A2的松弛
度可按下式算出:
A2的松弛度 =必须完成时间 -其本身的运行时间 -当前时间
=40 ms-10 ms-10 ms=20 ms
第三章 处理机调度与死锁
类似地, 可算出 B1的松弛度为 15ms,故调度程序应选择 B2
运行 。 在 t3=30 ms时, A2的松弛度已减为 0(即 40-10-30),而 B1
的松弛度为 15 ms(即 50-5-30),于是调度程序应抢占 B1的处理
机而调度 A2运行 。 在 t4=40 ms时, A3的松弛度为 10 ms(即 60-10-
40),而 B1的松弛度仅为 5 ms(即 50-5-40),故又应重新调度 B1执
行 。 在 t5=45 ms时, B1执行完成, 而此时 A3的松弛度已减为 5
ms(即 60-10-45),而 B2的松弛度为 30 ms(即 100-25-45),于是又
应调度 A3执行 。 在 t6=55ms时, 任务 A尚未进入第 4周期, 而任
务 B已进入第 2周期, 故再调度 B2执行 。 在 t7=70 ms时, A4的松
弛度已减至 0 ms(即 80-10-70),而 B2的松弛度为 20 ms(即 100-
10-70),故此时调度又应抢占 B2的处理机而调度 A4执行 。
第三章 处理机调度与死锁
图 3-9 利用 ELLF算法进行调度的情况
t
1
A
1
( 1 0 )
10 20 30 40 50 60 80
t
0
t
1
= 0
B
1
( 2 0 )
t
2
t
3
70
A
2
( 1 0 ) A
3
( 1 0 ) A
4
( 1 0 )
t
4
t
5
t
6
t
7
t
8
B
1
( 5 ) B
2
( 1 5 ) B
2
( 1 0 )
第三章 处理机调度与死锁
3.4 多处理机系统中的调度
3.4.1 多处理器系统的类型
(1) 紧密耦合 (Tightly Coupted)MPS。
这通常是通过高速总线或高速交叉开关, 来实现多个
处理器之间的互连的 。 它们共享主存储器系统和 I/O设备,
并要求将主存储器划分为若干个能独立访问的存储器模块,
以便多个处理机能同时对主存进行访问 。 系统中的所有资
源和进程, 都由操作系统实施统一的控制和管理 。
第三章 处理机调度与死锁
(2) 松散耦合 (Loosely Coupled)MPS。
在松散耦合 MPS中, 通常是通过通道或通信线路, 来
实现多台计算机之间的互连 。 每台计算机都有自己的存储
器和 I/O设备, 并配置了 OS来管理本地资源和在本地运行
的进程 。 因此, 每一台计算机都能独立地工作, 必要时可
通过通信线路与其它计算机交换信息, 以及协调它们之间
的工作 。
第三章 处理机调度与死锁
2,对称多处理器系统和非对称多处理器系统
(1) 对称多处理器系统 SMPS(Symmetric MultiProcessor
System)。 在系统中所包含的各处理器单元, 在功能和结构
上都是相同的, 当前的绝大多数 MPS都属于 SMP系统 。 例
如, IBM公司的 SR/6000 Model F50,便是利用 4片 Power PC
处理器构成的 。
(2) 非对称多处理器系统 。 在系统中有多种类型的处理
单元, 它们的功能和结构各不相同, 其中只有一个主处理
器, 有多个从处理器 。
第三章 处理机调度与死锁
3.4.2 进程分配方式
1,对称多处理器系统中的进程分配方式
在 SMP系统中, 所有的处理器都是相同的, 因而可把所
有的处理器作为一个处理器池 (Processor pool),由调度程序
或基于处理器的请求, 将任何一个进程分配给池中的任何一
个处理器去处理 。 在进行进程分配时, 可采用以下两种方式
之一 。
1) 静态分配 (Static Assigenment)方式
2) 动态分配 (Dynamic Assgement)
第三章 处理机调度与死锁
2,非对称 MPS中的进程分配方式
对于非对称 MPS,其 OS大多采用主 —从 (Master-Slave)
式 OS,即 OS的核心部分驻留在一台主机上 (Master),而从
机 (Slave)上只是用户程序, 进程调度只由主机执行 。 每当
从机空闲时, 便向主机发送一索求进程的信号, 然后, 便
等待主机为它分配进程 。 在主机中保持有一个就绪队列,
只要就绪队列不空, 主机便从其队首摘下一进程分配给请
求的从机 。 从机接收到分配的进程后便运行该进程, 该进
程结束后从机又向主机发出请求 。
第三章 处理机调度与死锁
3.4.3 进程 (线程 )调度方式
1,自调度 (Self-Scheduling)方式
1)
在多处理器系统中, 自调度方式是最简单的一种调度方
式 。 它是直接由单处理机环境下的调度方式演变而来的 。
在系统中设置有一个公共的进程或线程就绪队列, 所有的
处理器在空闲时, 都可自己到该队列中取得一进程 (或线程 )
来运行 。 在自调度方式中, 可采用在单处理机环境下所用的
调度算法, 如先来先服务 (FCFS)调度算法, 最高优先权优先
(FPF)调度算法和抢占式最高优先权优先调度算法等 。
第三章 处理机调度与死锁
2)
自调度方式的主要优点表现为:首先, 系统中的公共
就绪队列可按照单处理机系统中所采用的各种方式加以组
织; 其调度算法也可沿用单处理机系统所用的算法, 亦即,
很容易将单处理机环境下的调度机制移植到多处理机系统
中, 故它仍然是当前多处理机系统中较常用的调度方式 。
其次, 只要系统中有任务, 或者说只要公共就绪队列不空,
就不会出现处理机空闲的情况, 也不会发生处理器忙闲不
均的现象, 因而有利于提高处理器的利用率 。
第三章 处理机调度与死锁
3) 自调度方式的缺点
(1) 瓶颈问题。
(2) 低效性。
(3) 线程切换频繁。
第三章 处理机调度与死锁
2,成组调度 (Gang Scheduling)
在成组调度时, 如何为应用程序分配处理器时间,
1) 面向所有应用程序平均分配处理器时间
2) 面向所有线程平均分配处理器时间
图 3 - 10 两种分配处理器时间的方法
第三章 处理机调度与死锁
3,专用处理器分配 (Dedicated Processor Assigement)方式
图 3-11 线程数对加速比的影响
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
1
2
3
4
5
6
7
加速比
线程数
矩阵相乘
F F T
0
第三章 处理机调度与死锁
3.5 产生死锁的原因和必要条件
3.5.1 产生死锁的原因
(1) 竞争资源。
(2) 进程间推进顺序非法。
第三章 处理机调度与死锁
1,竞争资源引起进程死锁
1)
2) 竞争非剥夺性资源
3) 竞争临时性资源
第三章 处理机调度与死锁
图 3-12 I/O设备共享时的死锁情况
R
1
R
2
P
1
P
2
第三章 处理机调度与死锁
图 3-13 进程之间通信时的死锁
S
2
P
1
S
3
P
3
S
1
P
2
第三章 处理机调度与死锁
2,进程推进顺序不当引起死锁
1) 进程推进顺序合法
图 3-14 进程推进顺序对死锁的影响
P
2
R e l ( R
1
)
P
2
R e l ( R
2
)
P
2
R e q ( R
1
)
P
2
R e q ( R
2
)
P
1
R e q ( R
1
) P
1
R e q ( R
2
) P
1
R e l ( R
1
) P
1
R e l ( R
2
)




D
第三章 处理机调度与死锁
2)
若并发进程 P1和 P2按曲线 ④ 所示的顺序推进, 它们将进
入不安全区 D内 。 此时 P1保持了资源 R1,P2保持了资源 R2,系
统处于不安全状态 。 因为, 这时两进程再向前推进, 便可
能发生死锁 。 例如, 当 P1运行到 P1:Request(R2)时, 将因 R2
已被 P2占用而阻塞;当 P2运行到 P2,Request(R1)时, 也将因
R1已被 P1占用而阻塞, 于是发生了进程死锁 。
第三章 处理机调度与死锁
3.5.2 产生死锁的必要条件
(1) 互斥条件
(2) 请求和保持条件
(3) 不剥夺条件
(4) 环路等待条件
第三章 处理机调度与死锁
3.5.3 处理死锁的基本方法
(1) 预防死锁。
(2) 避免死锁。
(3) 检测死锁。
(4) 解除死锁。
第三章 处理机调度与死锁
3.6 预防死锁的方法
3.6.1 预防死锁
1,摒弃“请求和保持”条件
2,摒弃“不剥夺”条件
3,摒弃“环路等待”条件
第三章 处理机调度与死锁
3.6.2 系统安全状态
1,安全状态
在避免死锁的方法中, 允许进程动态地申请资源, 但系
统在进行资源分配之前, 应先计算此次资源分配的安全性 。
若此次分配不会导致系统进入不安全状态, 则将资源分配给
进程; 否则, 令进程等待 。
所谓安全状态, 是指系统能按某种进程顺序 (P1,P2,…,
Pn)(称 〈 P1,P2,…,Pn〉 序列为安全序列 ),来为每个进程 Pi分配
其所需资源, 直至满足每个进程对资源的最大需求, 使每个
进程都可顺利地完成 。 如果系统无法找到这样一个安全序列,
则称系统处于不安全状态 。
第三章 处理机调度与死锁
2.
我们通过一个例子来说明安全性 。 假定系统中有三个
进程 P1,P2和 P3,共有 12台磁带机 。 进程 P1总共要求 10台磁
带机, P2和 P3分别要求 4台和 9台 。 假设在 T0时刻, 进程 P1、
P2和 P3已分别获得 5台, 2台和 2台磁带机, 尚有 3台空闲未分
配, 如下表所示:
进 程 最 大 需 求 已 分 配 可 用
P1
P2
P3
10
4
9
5
2
2
3
第三章 处理机调度与死锁
3,由安全状态向不安全状态的转换
如果不按照安全序列分配资源, 则系统可能会由安全
状态进入不安全状态 。 例如, 在 T0时刻以后, P3又请求 1台
磁带机, 若此时系统把剩余 3台中的 1台分配给 P3,则系统
便进入不安全状态 。 因为, 此时也无法再找到一个安全序
列, 例如, 把其余的 2台分配给 P2,这样, 在 P2完成后只能
释放出 4台, 既不能满足 P1尚需 5台的要求, 也不能满足 P3
尚需 6台的要求, 致使它们都无法推进到完成, 彼此都在等
待对方释放资源, 即陷入僵局, 结果导致死锁 。
第三章 处理机调度与死锁
3.6.3 利用银行家算法避免死锁
1,银行家算法中的数据结构
(1) 可利用资源向量 Available。 这是一个含有 m个元素
的数组, 其中的每一个元素代表一类可利用的资源数目,
其初始值是系统中所配置的该类全部可用资源的数目, 其
数值随该类资源的分配和回收而动态地改变 。 如果
Available[ j] =K,则表示系统中现有 Rj类资源 K个 。
第三章 处理机调度与死锁
(2) 最大需求矩阵 Max。 这是一个 n× m的矩阵, 它定义了
系统中 n个进程中的每一个进程对 m类资源的最大需求 。 如果
Max[ i,j] =K,则表示进程 i需要 Rj类资源的最大数目为 K 。
(3) 分配矩阵 Allocation。 这也是一个 n× m的矩阵, 它定义
了系统中每一类资源当前已分配给每一进程的资源数 。 如果
Allocation[ i,j] =K,则表示进程 i当前已分得 Rj类资源的数目
为 K。
(4) 需求矩阵 Need。 这也是一个 n× m的矩阵, 用以表示每
一个进程尚需的各类资源数 。 如果 Need[ i,j] =K,则表示进程
i还需要 Rj类资源 K个, 方能完成其任务 。
Need[ i,j] =Max[ i,j] -Allocation[ i,j]
第三章 处理机调度与死锁
2,银行家算法
设 Requesti是进程 Pi的请求向量, 如果 Requesti[ j] =K,
表示进程 Pi需要 K个 Rj类型的资源 。 当 Pi发出资源请求后, 系
(1) 如果 Requesti[ j] ≤Need[ i,j], 便转向步骤 2;否则
认为出错, 因为它所需要的资源数已超过它所宣布的最大值 。
(2) 如果 Requesti[ j] ≤Available[ j], 便转向步骤 (3);否
则, 表示尚无足够资源, Pi须等待 。
第三章 处理机调度与死锁
(3) 系统试探着把资源分配给进程 Pi,并修改下面数据结
Available[ j] ∶ =Available[ j] -Requesti[ j] ;
Allocation[ i,j] ∶ =Allocation[ i,j] +Requesti[ j] ;
Need[ i,j] ∶ =Need[ i,j] -Requesti[ j] ;
(4) 系统执行安全性算法, 检查此次资源分配后, 系统是
否处于安全状态 。 若安全, 才正式将资源分配给进程 Pi,以
完成本次分配;否则, 将本次的试探分配作废, 恢复原来的
资源分配状态, 让进程 Pi等待 。
第三章 处理机调度与死锁
3,安全性算法
(1) 设置两个向量,① 工作向量 Work,它表示系统可提
供给进程继续运行所需的各类资源数目, 它含有 m个元素,
在执行安全算法开始时, Work∶ =Available; ② Finish,它表
示系统是否有足够的资源分配给进程, 使之运行完成 。 开
始时先做 Finish[ i] ∶ =false; 当有足够资源分配给进程时,
再令 Finish[ i] ∶ =true。
第三章 处理机调度与死锁
(2) 从进程集合中找到一个能满足下述条件的进程:
① Finish[ i] =false; ② Need[ i,j] ≤Work[ j] ; 若找
到, 执行步骤 (3),否则, 执行步骤 (4)。
(3) 当进程 Pi获得资源后, 可顺利执行, 直至完成, 并
释放出分配给它的资源,
Work[ j] ∶ = Work[ i] +Allocation[ i,j] ;
Finish[ i] ∶ = true;
go to step 2;
(4) 如果所有进程的 Finish[ i] =true都满足, 则表示系
统处于安全状态;否则, 系统处于不安全状态 。
第三章 处理机调度与死锁
4,银行家算法之例
假定系统中有五个进程 { P0,P1,P2,P3,P4} 和三类资源 { A,
B,C}, 各种资源的数量分别为 10,5,7,在 T0时刻的资源分
配情况如图 3-15 所示 。
图 3-15 T0时刻的资源分配表
第三章 处理机调度与死锁
(1) T0时刻的安全性:
图 3-16 T0时刻的安全序列
第三章 处理机调度与死锁
(2) P1请求资源,P1发出请求向量 Request1(1,0,2),
系统按银行家算法进行检查:
① Request1(1,0,2)≤Need1(1,2,2)
② Request1(1,0,2)≤Available1(3,3,2)
③ 系统先假定可为 P1分配资源, 并修改 Available,
Allocation1和 Need1向量, 由此形成的资源变化情况如图 3-
15 中的圆括号所示 。
④ 再利用安全性算法检查此时系统是否安全。
第三章 处理机调度与死锁
图 3-17 P1申请资源时的安全性检查
第三章 处理机调度与死锁
(3) P4请求资源,P4发出请求向量 Request4(3,3,0),系
① Request4(3,3,0)≤Need4(4,3,1);
② Request4(3,3,0) < Available(2,3,0),让 P4等待 。
(4) P0请求资源,P0发出请求向量 Requst0(0,2,0),系统按
① Request0(0,2,0)≤Need 0(7,4,3);
② Request0(0,2,0)≤Available(2,3,0);
③ 系统暂时先假定可为 P0分配资源,并修改有关数据,
如图 3-18 所示。
??
第三章 处理机调度与死锁
图 3-18 为 P0分配资源后的有关资源数据
第三章 处理机调度与死锁
3.7 死锁的检测与解除
3.7.1 死锁的检测
1,资源分配图 (Resource Allocation Graph)
图 3-19 每类资源有多个时的情况
P
1
P
2
r
1
r
2
第三章 处理机调度与死锁
(2) 凡属于 E中的一个边 e∈ E,都连接着 P中的一个结点
和 R中的一个结点, e={pi,rj}是资源请求边, 由进程 pi指向
资源 rj,它表示进程 pi请求一个单位的 rj资源 。 e={rj,pi}是
资源分配边, 由资源 rj指向进程 pi,它表示把一个单位的资
源 rj分配给进程 pi。
第三章 处理机调度与死锁
2,死锁定理
图 3-20 资源分配图的简化
( a ) ( b )
P
1
( c )
P
1
P
2
P
1
P
2
P
2
第三章 处理机调度与死锁
3,死锁检测中的数据结构
(1) 可利用资源向量 Available,它表示了 m类资源中每一
类资源的可用数目 。
(2) 把不占用资源的进程 (向量 Allocation∶ =0)记入 L表中,
即 Li∪ L。
(3) 从进程集合中找到一个 Requesti≤Work的进程, 做如下
处理,① 将其资源分配图简化, 释放出资源, 增加工作向量
Work∶ =Work+Allocationi。 ② 将它记入 L表中 。
第三章 处理机调度与死锁
(4) 若不能把所有进程都记入 L表中, 便表明系统状态 S
的资源分配图是不可完全简化的 。 因此, 该系统状态将发生
死锁 。 Work ∶ =Available;
L ∶ = {Li|Allocationi=0∩Requesti=0}
for all Li L do
begin
for all Requesti≤Work do
begin
Work ∶ =Work+Allocationi;
Li∪ L;
end
end
deadlock∶ = (L={p1,p2,…,p n});
?
第三章 处理机调度与死锁
3.7.2 死锁的解除
(1) 剥夺资源。
(2) 撤消进程。
为把系统从死锁状态中解脱出来, 所花费的代价可
表示为:
R(S)min=min{Cui}+min{Cuj}+min{Cuk}+…
第三章 处理机调度与死锁
图 3-21 付出代价最小的死锁解除方法
U
1
V
12
V
13
V
1k
W
132
W
134
W
13k
P
2
P
3


P
2
P
4
… P
k

P
k
U
2
V
21
V
22
V
2k
W
231
W
234
W
23k

P
1
P
4
… P
k

U
k
V
k1
V
k2
V
kk
W
k21
W
k22
W
k2k


P
k
… …
S
P
1
(c
u1
) P
1
(c
uk
)
P
1
(c
ud
)