美文网首页操作系统
死锁的四个必要条件

死锁的四个必要条件

作者: 捡书 | 来源:发表于2017-04-06 16:20 被阅读70次

一. 什么是死锁?

 如果一个进程集合里面的每个进程都在等待这个集合中的其他一个进程(包括自身)才能继续往下执行,若无外力他们将无法推进,这种情况就是死锁,处于死锁状态的进程称为死锁进程

二. 死锁产生的原因?

1.因竞争资源发生死锁 现象:系统中供多个进程共享的资源的数目不足以满足全部进程的需要时,就会引起对诸资源的竞争而发生死锁现象

(1)可剥夺资源和不可剥夺资源:可剥夺资源是指某进程在获得该类资源时,该资源同样可以被其他进程或系统剥夺,不可剥夺资源是指当系统把该类资源分配给某个进程时,不能强制收回,只能在该进程使用完成后自动释放

(2)竞争不可剥夺资源:系统中不可剥夺资源的数目不足以满足诸进程运行的要求,则发生在运行进程中,不同的进程因争夺这些资源陷入僵局。

举例说明: 资源A,B; 进程C,D

资源A,B都是不可剥夺资源:一个进程申请了之后,不能强制收回,只能进程结束之后自动释放。内存就是可剥夺资源

进程C申请了资源A,进程D申请了资源B。

接下来C的操作用到资源B,D的资源用到资源A。但是C,D都得不到接下来的资源,那么就引发了死锁。

(3)竞争临时资源

2.进程推进顺序不当发生死锁

三. 产生死锁的四个必要条件?

(1)互斥条件:进程对所分配到的资源不允许其他进程进行访问,若其他进程访问该资源,只能等待,直至占有该资源的进程使用完成后释放该资源

(2)请求和保持条件:进程获得一定的资源之后,又对其他资源发出请求,但是该资源可能被其他进程占有,此事请求阻塞,但又对自己获得的资源保持不放

(3)不可剥夺条件:是指进程已获得的资源,在未完成使用之前,不可被剥夺,只能在使用完后自己释放

(4)环路等待(循环等待)条件:是指进程发生死锁后,必然存在一个进程--资源之间的环形链,通俗讲就是你等我的资源,我等你的资源,大家一直等。

四. 处理死锁的基本方法

1.预防死锁:通过设置一些限制条件,去破坏产生死锁的必要条件,像银行家算法之类的。

2.避免死锁:在资源分配过程中,使用某种方法避免系统进入不安全的状态,从而避免发生死锁

3.检测死锁:允许死锁的发生,但是通过系统的检测之后,采取一些措施,将死锁清除掉

4.解除死锁:该方法与检测死锁配合使用

相关文章

  • 揭秘:“死锁”四个必要条件的合理解释

    《“死锁”四个必要条件的合理解释》分为三个部分: 【1】“死锁”的含义 【2】“死锁”的原因及四个必要条件的合理解...

  • “死锁”四个必要条件的合理解释

    《“死锁”四个必要条件的合理解释》分为三个部分: 【1】“死锁”的含义 【2】“死锁”的原因及四个必要条件的合理解...

  • java多线程笔记

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

  • 线程池系列(5)记一次JDK线程池死锁

    什么?JDK线程池还会死锁? 1. 死锁产生的必要条件 产生死锁的四个必要条件:(1) 互斥条件:一个资源每次只能...

  • Java死锁

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

  • Java锁(悲观、乐观锁、CAS原子操作)

    Java死锁发生的必要条件 Java死锁产生的四个必要条件: 互斥使用,即当一个线程占用了资源,其他线程不能使用。...

  • 死锁

    以下内容整理自互联网,仅用于个人学习 1. 死锁的必要条件 死锁必须满足四个必要条件,缺一不可。 互斥条件:进程要...

  • 7-8.死锁与分页

    七、死锁 概念 死锁的特征(四个条件同时出现,死锁将会发生(必要条件))互斥:一次只有一个进程可以使用一个资源占有...

  • Java死锁分析

    死锁是多进程环境下的一种假死现象,即产生死锁的进程都处于等待状态。只要满足了下面四个必要条件,就有可能产生死锁: ...

  • 一个死锁的例子

    先举个栗子。 产生死锁的原因主要是: 系统资源不足 资源分配不当 推进顺序不合适 产生死锁的四个必要条件: 互斥:...

网友评论

    本文标题:死锁的四个必要条件

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