死锁

以下内容整理自互联网,仅用于个人学习


1. 死锁的必要条件

死锁必须满足四个必要条件,缺一不可。

  • 互斥条件:进程要求对所分配的资源进行排他性控制,即在一段时间内某资源仅为一个进程所占有。此时若有其他进程请求该资源,则请求进程只能等待。
  • 不剥夺条件:进程所获得的资源在未使用完毕之前,不能被其他进程强行夺走,即只能有获得该资源的进程自己来释放(只能是主动释放)。
  • 请求和保持条件:进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源已经被其他进程占有,此时请求被阻塞,但对自己已获得的资源保持不放。
  • 循环等待条件:存在一种进程资源的循环等待链,链中每一个进程已获得的资源同时被链中下个进程所请求。

2. 死锁的处理策略

2.1 预防死锁

设置某些限制条件,破坏产生死锁的四个必要条件,以防发生死锁

2.2 避免死锁

在资源动态分配过程中,防止系统进入不安全状态,以避免发生死锁

2.3 死锁的检测与解除

死锁解除方法:

  • 资源剥夺法。挂起某些死锁进程,并抢占它的资源,将这些资源分配给其他进程。但应该防止被挂起的进程长时间得不到资源,而处于资源匮乏的状态。
  • 撤销进程法。强制撤销部分、甚至全部死锁进程并剥夺这些进程的资源。撤销的原则可以按进程优先级和撤销进程代价的高低进行。
  • 进程回退法。让一(多)个进程回退到足以回避死锁的地步,进程回退时自愿释放资源而不是剥夺。要求系统保持进程的历史信息,设置还原点。

处理策略的比较:

| | 资源分配策略 | 各种可能模式 | 主要优点 | 主要缺点 |
| -- |: ----------------: | :----------: | :----------: | :-------: |
| 死锁预防 | 保守,宁可资源闲置 | 一次请求所有资源,资源剥夺,资源按序分配 | 适用于做突发式处理的进程,不必进行剥夺 | 效率低,进程初始化时 间延长;剥夺次数过多; 不便灵活申请新资源 |
| 死锁避免 | 是”预防“和”检测“ 的折中(在运行时判断是 否可能死锁) | 寻找可能的安全允许顺序| 不必进行剥夺 | 必须知道将来的资源 需求;进程不能被长时间阻塞 |
| 死锁检测 | 宽松,只要允许就分配资源| 定期检查死锁是否已经发生 | 不延长进程初始化时间,允许对死锁进行现场处理 | 通过剥夺解除死锁,造成损失 |

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1、竞态条件: 定义:竞态条件指的是一种特殊的情况,在这种情况下各个执行单元以一种没有逻辑的顺序执行动作,从而导致...
    Hughman阅读 1,338评论 0 7
  • 死锁的定义 进程之间互相等待资源又都不能向前推进的情况,即造成进程相互死等的局面。即每个进程“抓住”一些为其他进程...
    曲谐_阅读 812评论 0 1
  • 死锁产生的原因和解锁的方法 产生死锁的四个必要条件: (1) 互斥条件:一个资源每次只能被一个进程使用。 (2) ...
    憩在河岸上的鱼丶阅读 1,501评论 0 4
  • 资源问题 在系统中有许多不同类型的资源,其中可以引起死锁的主要是,需要采用互补访问方式的、不可以被抢占的资源,即临...
    NoFacePeace阅读 1,122评论 0 0
  • “每一位小baby都是上帝牵着手来到世上的,都是父母最亲爱的宝贝,没有任何一个是意外!”这是《命中注定我爱你》...
    蓝色的芒果干阅读 333评论 0 2