死锁

作者: Vett | 来源:发表于2017-07-29 18:38 被阅读0次

1. 什么是死锁

1.1. 什么是资源

计算机排他性的访问并使用的对象,叫做资源.资源按照其调度方案可以分为可抢占资源不可抢占资源两种.

  1. 可抢占资源:从占有它的进程中抢占不会引起错误的资源,例如存储器等.

  2. 不可抢占资源:不引起进程故障的情况下,无法从占有它的进程中抢占的资源,例如打印机等.

死锁和不可抢占资源有关.

1.2. 死锁

死锁是一种场景.

假设有A和B两个进程.A进程持有资源R,请求资源Q.B进程持有资源Q,请求资源R.而且A和B在未完成各自作业之前,不会释放已持有的资源.

当R和Q资源都是不可抢占资源时,就发生了死锁.

因为操作系统调度程序在通常情况下不会对已分配的不可抢占资源进行重分配,而是等待占有它的进程显示释放.

2. 形成条件

  1. 互斥条件: 资源只有两种状态.要么分配给了进程,要么就是可用的.

  2. 占有和等待条件: 已经得到某个资源的进程可以再次请求新的资源.

  3. 不可抢占条件: 已经分配的资源不能被抢占,只能由占有它的进程显式释放.

  4. 环路等待条件: 死锁发生时,系统中一定由两个或两个以上的进程组成一条环路,该环路中,每个进程都在等待下一个进程所占有的资源.

3. 避免

没有一种算法可以完全避免所有环境中可能发生的死锁.只能通过运行时场景来选择合理的方式避免.

比如,数据库为了避免死锁,采用的两阶段加锁,不适用于进程作业不确定的场景.

再如,存储空间大的系统可以采用守护进程加假脱机打印目录来解决打印机死锁,但不适用于小存储空间系统.

3.1. 银行家算法

银行家算法是指,银行家将定量的资金贷给若干个企业家,企业家需求资金总量已知,但是资金不会全部立即到账,只能由企业家分阶段申请.企业家在获得全部所需资金后归还全部资金.通过银行家算法,银行家可以完美调度资金,满足所有企业家的需求.

但是,银行家算法只能作为参考,而没有通用性.因为,讲资金换成资源,银行家换成操作系统,几乎所有的进程在运行前是不知道自己所需某种资源的数量.

在一些大型批处理作业中,可以参考银行家算法来避免死锁.

以下是多种资源的银行家算法(单个资源的银行家算法也适配于此):

假设:

  1. 有m种资源.有n个进程.
  2. 各个资源总数组成的向量为E.


    E.gifE.gif
  3. 各个资源剩余量组成的向量为A.


    A.gifA.gif
  4. C为当前分配资源.


    C.gifC.gif
  5. R为请求资源.


    R.gifR.gif

存在恒等式:


sum.gifsum.gif

算法描述如下:

  1. 检查R中是否有一行,满足各项都小于A.
  2. 如果有,则分配.进程被标记.之后释放所有资源,加到A中.
  3. 重复以上步骤,直到所有进程被标记.如果存在无法标记的进程,则当前分配方案存在死锁.

3.2. 破坏死锁形成条件

这种方法是破坏思索形成四个条件中的任意一个,从而避免思索.每个条件的背后都有隐含的条件,并不适用于所有场景,只能因地制宜,选择最合适的方法.

3.2.1. 破坏互斥条件

方法: 假脱机,由守护进程专门负责资源操作.

问题: 以假脱机打印为例,如果假脱机目录在接收到文件时就开始打印.这样一来,存储空间的需求就是未知的.如果文件就绪再打印,那么脱机打印目录在空间有限的前提下,本身就会发生死锁.因为可能所有的进程在写入一半时,空间满了.

3.2.2. 破坏占有和等待条件

方法: 在进程开始前请求所有资源.

问题: 一般情况下,进程是不知道自己将来的资源需求的.

3.2.3. 破坏不可抢占条件

方法: 抢占.

问题: 在一般进程间会发生错误.

3.2.4. 破坏环路等待条件

方法1: 每个进程只能拥有一个资源.

问题: 如果有需要两个资源的进程,则这个进程无法运行.

方法2: 给每个资源编号,然后进程按照标号增(或减)序,申请资源.

问题: 每个进程申请资源的刚性顺序貌似是随机的.所以,宏观来看,不存在一种可以运行所有进程的资源排序.

4. 综上所述

想要在全部维度完全避免死锁,为此寻找一个一劳永逸的方法,当前是不可能的.所以要在有死锁发生潜在可能的环境中,根据需求,合理的选择避免死锁的方法.其中可能包含银行家算法,也可以打破死锁发生的条件.或者使用特殊的资源调度算法.

来自博客:http://newlooc.com

相关文章

  • 死锁

    线程饥饿死锁 锁顺序死锁 动态锁顺序死锁通过锁顺序来避免死锁 避免死锁

  • 死锁

    第11章:死锁和进程通信 死锁概念 死锁处理方法 死锁预防(Deadlock Prevention) 死锁避免(D...

  • java多线程笔记

    产生死锁的四个必要条件 处理死锁的基本方法 死锁预防 死锁避免 死锁检测 死锁解除 https://blog.cs...

  • [现代操作系统]--死锁

    table of content 死锁定义 死锁建模-- 资源分配图 处理死锁鸵鸟算法检测并恢复死锁检测死锁恢复利...

  • Java-多线程(四)死锁

    死锁 死锁示例

  • Java死锁

    什么是死锁 死锁检测 产生死锁的四个必要条件 如何避免死锁 死锁 死锁,指两个或多个线程之间,由于互相持有对方需要...

  • java并发--java死锁

    本篇结构: 前言 什么是死锁 产生死锁的必要条件 死锁的代码示例 死锁排查 如何避免死锁 总结 一、前言 今天被问...

  • Java多线程之死锁(Deadlock)及死锁避免(Deadlo

    线程死锁(Thread Deadlock) 数据库死锁(Database Deadlocks) 死锁避免 (Dea...

  • JavaEE面试题总结 Day39 2018-12-29

    什么是线程死锁?死锁如何产生?如何避免线程死锁? 死锁的介绍: 线程死锁是指由于两个或者多个线程互相持有对方所需要...

  • Java并发之嵌套管程锁死(Nested Monitor Loc

    嵌套管程死锁是如何发生的 具体的嵌套管程死锁的例子 嵌套管程死锁 vs 死锁 嵌套管程锁死类似于死锁, 下面是一个...

网友评论

    本文标题:死锁

    本文链接:https://www.haomeiwen.com/subject/hzyclxtx.html