3-5死锁概述
死锁(Deadlock):指多个进程在运行过程中,因争夺资源而造成的一种僵局。当进程处于这种状态时,若无外力作用,它们都将无法再向前推进。
死锁(Deadlock): 指进程之间无休止地互相等待!
饥饿(Starvation):指一个进程无休止地等待!
产生死锁的原因:
1 竞争资源。系统中供多个进程共享的资源如打印机、公用队列等的数目不满足需要时,会引起资源竞争而产生死锁。
系统中资源分两类:1可剥夺和非剥夺性资源 2永久性资源和临时性资源
2 进程间推进顺序非法。进程在运行过程中,请求和释放资源的顺序不当,同样会导致死锁。
多个进程按向前推进的顺序有两种情况: 推进顺序合法&推进顺序非法
产生死锁的必要条件:互斥条件,请求和保持条件,不剥夺条件,环路等待条件。
处理死锁的基本方法:1事先预防:1.1预防死锁1.2避免死锁
2事后处理:2.1检测死锁。2.2解除死锁
3-6.7预防与避免死锁
1摒弃“请求和保持”条件。2摒弃“不剥夺”条件:允许进程先运行。3 摒弃“环路等待”条件
安全状态:系统能按某种进程顺序为每个进程分配所需资源,直至满足每个进程对资源的最大需求,并能顺利完成。
不安全状态:系统无法找到一种使多个进程能够顺利分配资源执行完的安全序列。
银行家算法避免死锁。
3.8死锁的检测与解除
检测时机:1当进程等待时检测死锁
2定时检测
3系统资源利用率下降时检测死锁
利用资源分配图简化法来检测死锁。
若要使当前运行进程总是优先级最高的进程,则应选择:可抢占优先级调度算法。
分时系统中,进程调度经常采用:时间片轮转调度算法。
进程调度采用时间片轮转法时,时间片过大,就会使轮转法转化为:先来先服务调度算法。
进程的调度方式有两种:可抢占和非抢占方式。
可引起进程调度的原因:进程运行结束
进入阻塞状态
时间片用完
有更高优先级的进程进入就绪队列
在有m个进程的系统中出现死锁时,死锁进程的个数k满足条件:2<=k<=m。
不让死锁发生的策略可分为静态和动态两种,死锁避免属于:动态策略。
预先静态分配法可以破坏:占有且等待条件。
资源的按序分配策略可以破坏:环路等待条件。