第三章 处理机调度与死锁2

本文深入探讨了死锁的概念,包括其定义、产生原因及必要条件。详细讲解了预防、避免、检测与解除死锁的方法,以及如何通过银行家算法避免死锁。同时,文章还分析了进程调度算法,如时间片轮转法和可抢占优先级调度算法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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。
不让死锁发生的策略可分为静态和动态两种,死锁避免属于:动态策略。
预先静态分配法可以破坏:占有且等待条件。
资源的按序分配策略可以破坏:环路等待条件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值