ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

《OS:死锁预防与死锁避免》

2021-07-03 16:03:24  阅读:175  来源: 互联网

标签:OS 安全 死锁 抢夺 序列 进程 预防 资源


死锁预防

法1:破坏进程间的互斥条件

这个方法简单粗暴,由于死锁产生的原理即是因为不可抢夺的资源而产生的。程序之间存在互斥性。该方法就是让不可抢夺变成可抢夺。这样看起来有效,但是实际上因为某些资源本身具有不可抢占性而往往不能被抢占。该方法也不能被使用。例如在刻光盘的时候,我们难道去剥夺他的占有权吗,这会导致灾难性的后果,就像我在刻录一个计算机网络的资料,突然被剥夺了,刻到一半刻去了操作系统的内容,这显然是不合理的。这就是因为资源本身具备不可抢占性。

法2:破坏占有且等待条件

有两个实施方案:

  1. 预分配资源策略
  2. “空手”申请资源策略

预分配资源策略
意为:在进程开始执行之前就申请所需的所有资源。是一种资源的静态分配


“空手”申请资源策略
每个程序仅在他不占据其他资源的时候才能申请资源。

缺点分析

  1. 不可能提前预知进程在执行的时候需要的全部资源
  2. 资源利用率低
  3. 降低了并发性
  4. 部分进程饥饿

法3:破坏非抢占条件

在进程拥有其他资源但是需要申请更多的资源的时候,他自身本来占有的资源可以被其他进程所抢夺。这样就能预防死锁的发生

法4:破坏循环等待条件

实行资源有序分配策略:所有的进程对资源的申请个严格按照已经安排好的额序号递增的次序进行。

死锁的避免

相比与死锁的预防来说,死锁的避免就是一种动态的排除死锁的策略。核心是确定资源分配的安全性

何为安全?

若存在一个安全序列,则表示该系统的分配状态是安全的

何为安全序列?

安全序列即定义为{ Pi , Pi+1, … , Pn },该序列按序执行下去可以让计算机不发生资源不足的问题。注意安全序列的执行是单道顺序进行的。

如果一个分配状态中满足存在一个安全序列,则表示该分配状态是安全的。否则就是不安全的
但是系统进入不安全状态也未必会发生死锁。但是发生死锁,一定是不安全的状态。
这里具体涉及到就是银行家算法了。

标签:OS,安全,死锁,抢夺,序列,进程,预防,资源
来源: https://blog.csdn.net/weixin_45864947/article/details/118440232

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有