计算机操作系统基础(七)---作业管理之死锁

引言

本文为第七篇,作业管理之死锁,死锁是计算机操作系统中非常重要的概念,本文主要介绍什么是死锁以及如何解决死锁

死锁

死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程

举个例子:


image

如果这四辆汽车按照如图的方向行驶,堵在十字路口,相互之间没有退让的话,这四辆汽车就形成了死锁。

死锁的产生

  • 竞争资源
  • 进程调度顺序不当

竞争资源

为什么会出现竞争资源?

  • 共享资源数量不满足各个进程的需求
  • 各个进程之间发生资源竞争导致死锁

举例:

假设有两个进程:进程1和进程2,进程1需要使用传真机,并且已经获取到了传真机资源。进程2需要获取打印机,并且也获取到了。如果此时进程2还需要传真机的时候,或者进程1还需要打印机的时候,他们都需要等待请求的资源被释放,但他们相互之间所占用的资源又不会被释放,因此就造成了死锁的产生,这个就是由于竞争资源而产生的死锁。如果此时多一个传真机或者打印机资源,就不会出现死锁,本质还是因为资源不够

image

进程调度顺序不当

还是以上边的进程1和进程2为例,假设进程1申请传真机资源为步骤A,进程2申请打印机资源为步骤B,进程2申请传真机资源为步骤C,进程1申请打印机资源为步骤D。如果这两个进程按照A、B、C、D的顺序申请资源,就会产生死锁。如果程序可以把调度顺序改为A、D、B、C,这个时候就不会出现死锁的情况。因为当进程1先获得了传真机资源,然后在获取打印机资源,完成它的工作之后,进程1就会释放这两个资源。这个时候进程2就可以获得打印机和传真机资源了。这个就是因为进程调度顺序不当导致死锁的产生

image

死锁的四个必要条件

  • 互斥条件
  • 请求保持条件
  • 不可剥夺条件
  • 环路等待条件

如果只满足上边的一个或两个的话,不会产生死锁

互斥条件

  • 进程对资源的使用是排他性的使用
  • 某个资源只能由一个进程使用,其它需要使用该资源的进程只能等待,等待资源被释放

请求保持条件

  • 进程至少持有一个资源,又提出新的资源请求
  • 新资源被占用,请求被阻塞
  • 被阻塞的进程不释放自己所持有的资源

不可剥夺条件

  • 进程获得的资源在未完成使用前不能被剥夺(程序或操作系统均不可)
  • 获得的资源只能由进程自身释放

环路等待条件

发生死锁时,必然存在进程-资源环形链

P为进程,R为资源

image

死锁的处理

预防死锁的方法

前边提到了死锁的四个必要条件,只要破坏其中的一个或多个条件,就可以避免死锁的出现

破坏请求保持条件

  • 系统规定进程运行之前,一次性申请所有需要的资源
  • 进程在运行期间不会提出资源请求,从而摒弃请求保持条件。也就不可能会因为在运行的时候请求资源而导致等待的情况

破坏不可剥夺条件

  • 当一个进程请求新的资源得不到满足时,必须释放占有的资源
  • 进程运行时占有的资源可以被释放,意味着可以被剥夺

破坏环路等待条件

  • 可用资源线性排序,申请必须按照需要递增申请
  • 线性申请不再形成环路,从而摒弃了环路等待条件
image

假设有A、B、C、D、E这五个资源,按照线性顺序将他们排起来,假设有一个进程需要A和D这两个资源的时候,它必须先申请A,才能申请D,这样就是线性申请

银行家算法

银行家算法是一个可操作的著名的避免死锁的算法,以银行借贷系统分配策略为基础的算法

  • 假设客户申请的贷款是有限的,每次申请需要声明最大资金量
  • 银行家在能满足贷款时,都应该给客户贷款
  • 客户在使用贷款后,能够及时归还贷款

上边是银行家算法策略的一个基础,下边是具体过程:

这个算法要求有三个数据结构,分别是已分配资源表所需资源表可分配资源表

image

A、B、C、D为可申请的共享资源,P1、P2、P3、P4为需要申请资源的四个进程

已分配资源表

表中的数值表示的是每个进程它当前拥有的资源(如P1进程已分配了1个C资源和4个D资源)

所需资源表

表中的数值表示的是每个进程所需要各个资源的数量(如P1进程需要6个B资源、5个C资源和6个D资源)

可分配资源表

表中的数值表示的是系统里边还剩下的各种类型资源的数量

有了上边的几个数据结构的表格,就可以进行真实的演练了

(1)所需资源表已分配资源表

这两个数据结构相减,得到还需分配资源表,然后将还需分配资源表和可分配资源表进行对比

image

我们会发现,可分配资源表,不满足进程P1的需求,因为P1进程需要6个B资源、4个C资源、2个D资源,而可用的A、B、C、D资源分别只有1、5、2、0个,因此不满足进程PA的需求。后边的P2、P3、P4使用同样的方法对比可发现,可分配资源表中的资源满足P2的需求,不满足P1、P3、P4的需求。因此,系统会把可分配的资源全部分发给P2,那么这个P2进程就可以继续的执行下去,等P2执行完之后,再归还所有的资源,归还之后,又可以将新的资源分配给别的进程。这个就是银行家算法。(P1、P2、P3、P4可以看做贷款的人,数字代表贷款的钱)

在快速变化的技术中寻找不变,才是一个技术人的核心竞争力。知行合一,理论结合实践


image
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342