《“死锁”四个必要条件的合理解释》分为三个部分:

【1】“死锁”的含义

【2】“死锁”的原因及四个必要条件的合理解释

【3】“死锁”的预防和解除

1.“死锁”的含义

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

2.“死锁”产生的原因以及四个必要条件的合理解释

产生死锁的原因可归结为如下两点:

(1)竞争资源。当系统中供多个进程共享的资源如打印机、公用队列等,其数目不足以满足进程的需要时,会引起诸进程的竞争而产生死锁。

(2)进程间推进顺序非法。进程在运行过程中,请求和释放资源的顺序不当,也同样会导致产生进程死锁。

产生死锁的四个必要条件:

1.互斥(Mutual exclusion):存在这样一种资源,它在某个时刻只能被分配给一个执行绪(也称为线程)使用;

2.持有(Hold and wait):当请求的资源已被占用从而导致执行绪阻塞时,资源占用者不但无需释放该资源,而且还可以继续请求更多资源;

3.不可剥夺(No preemption):执行绪获得到的互斥资源不可被强行剥夺,换句话说,只有资源占用者自己才能释放资源;

4.环形等待(Circular wait):若干执行绪以不同的次序获取互斥资源,从而形成环形等待的局面,想象在由多个执行绪组成的环形链中,每个执行绪都在等待下一个执行绪释放它持有的资源。对于新手小白想更轻松的学好Java提升,Java架构,web开发、大数据,数据分析,人工智能等技术,这里给大家分享系统教学资源,扩列下我尉(同英):1253431195【教程/工具/方法/解疑】

发现到目前为止,所有的内容都可以在课本书籍、百度、论坛、博客上找到,似乎是教条的罗列。

我们发现看过多次,但每每需要的时候(开发、笔试、面试)却总要回头再看难以摆脱遗忘、记忆的循环我觉得产生这种现象的原因是因为:停留在机械记忆。

因为我们的教科书、论坛、博客的内容十有八九在罗列这些概念~但很少有进一步解释、阐释其存在的必然(四个必然条件为什么不多一个,又为什么不少一个?)及其内在逻辑。

或许下面的阐释能让你再遇到这个问题时,可以不翻教科书,不上网百度就能侃侃而谈~

<1>.“死锁”产生有几个必要条件?

“死锁”中“死”音通“四”是四个条件。(虽然很牵强,但对于识记,你会发现很有用!)

<2>.“四”锁的必要条件都是指哪些?

1.资源互斥性(资源的属性,不会同时属于/分配给多个进程)->2.持有和等待(进程被分配(持有)资源后而且在等待(申请)其他资源)->3不可剥夺(对于已分配的资源,不可再强制收回来)->4.环形等待(进程之间资源等待形成相互依赖,互不礼让)

用再通俗的话,进一步解释这个逐渐升级的状况。1->2->3->4是资源分配逐渐条件递进、加强、升级的过程:资源是互斥的每次属于一个进程(1.互斥);

资源分配了我占着而且我还要申请其他资源(2.持有和等待);

我占着的资源你没法拿,你占着的资源我没法拿(3.不可剥夺);

我申请的资源在你那,你申请的资源在我这(4.循环等待),最终形成了一个相互占有、相互等待的僵持局面~

3.“死锁”的预防和解除

理解了死锁的原因,尤其是产生死锁的四个必要条件,就可以最大可能地避免、预防和解除死锁,消除产生死锁的四个必要条件中的任何一个都可以预防和解除死锁。对于新手小白想更轻松的学好Java提升,Java架构,web开发、大数据,数据分析,人工智能等技术,这里给大家分享系统教学资源,扩列下我尉(同英):1253431195【教程/工具/方法/解疑】

不难看出,在死锁的四个必要条件中,第二、三和四项条件比较容易消除。

1、静态分配:采用资源静态分配策略(进程资源静态分配方式是指一个进程在建立时就分配了它需要的全部资源),破坏"部分分配"条件;

2、可剥夺:允许进程剥夺使用其他进程占有的资源,从而破坏"不可剥夺"条件;

3、有序分配:采用资源有序分配法,破坏"环路"条件。

“死锁”四个必要条件的合理解释相关推荐

  1. [ReentrantLock] 破坏死锁四个必要条件

    参考资料:https://www.bilibili.com/video/BV19E411k7Ni?p=78 北京大学<操作系统原理> 解决死锁的方法 1. 死锁预防: 2. 死锁避免 3. ...

  2. 死锁四个必要条件及死锁的预防、检测、避免、解除

    死锁: 我们先来思考一个问题:我们加锁以后,再次进行加锁,这样会发生什么? 当我们第二次申请锁的时候,这个时候锁已经被占用了,该线程就会被挂起,但是刚好这个线程就是拥有锁的线程了,那么这个线程就永远挂 ...

  3. 操作系统 死锁四个必要条件

    产生死锁的四个必要条件: 1. 互斥条件:一个资源每次只能被一个进程使用. 2. 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放. 3. 不剥夺条件:进程已获得的资源,在末使用完之 ...

  4. 死锁的四个必要条件,及处理方法

    死锁的四个必要条件互斥条件(Mutual exclusion):资源不能被共享,只能由一个进程使用.请求与保持条件(Hold and wait):已经得到资源的进程可以再次申请新的资源.非剥夺条件(N ...

  5. 死锁的四个必要条件及处理死锁

    什么是死锁? 如果一个进程集合里面的每个进程都在等待只能由这个集合中的其他一个进程(包括他自身)才能引发的事件,这种情况就是死锁. 这个定义可能有点拗口,下面用一个简单例子说明. 资源A.B,进程C. ...

  6. 面试问题之操作系统:死锁的四个必要条件和解决办法

    面试问题之操作系统:死锁的四个必要条件和解决办法 参考文章: (1)面试问题之操作系统:死锁的四个必要条件和解决办法 (2)https://www.cnblogs.com/yichengming/p/ ...

  7. linux进程--死锁产生的原因及四个必要条件(六)

    产生死锁的原因主要是: 因为系统资源不足. 进程运行推进的顺序不合适. 资源分配不当等. 如果系统资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁.其 ...

  8. 什么是死锁?死锁产生的四个必要条件?如何避免与预防死锁?

    一:什么是死锁 死锁是指多个进程因竞争资源而造成的一种僵局(互相等待),若无外力作用,这些进程都将无法向前推进.例如,在某一个计算机系统中只有一台打印机和一台输入 设备,进程P1正占用输入设备,同时又 ...

  9. 死锁产生的原因及四个必要条件

    产生死锁的原因主要是: (1) 因为系统资源不足. (2) 进程运行推进的顺序不合适. (3) 资源分配不当等. 如果系统资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则 就会因争 ...

最新文章

  1. iOS 6上的Safari是否缓存$ .ajax结果?
  2. linux /proc/net/tcp 文件分析
  3. Extjs 4.0.7 中模式窗口的CURD
  4. 17届中职计算机应用基础,西安交通大学17年3月课程考试《计算机应用基础》作业考核试题...
  5. Leetcode--全排列(Java)
  6. mac 修改conda镜像 condarc_win10 修改anaconda源
  7. yii 设置时区 不生效_Java 程序处理异地机房不同时区问题
  8. linux中文件查找命令
  9. Django实现web端tailf日志文件
  10. PID参数自整定库之一:继电反馈整定算法
  11. 抖音快手皮皮虾西瓜头条等等短视频去水印接口【11-20日更新】
  12. python 拼接 遥感影像_Python干货 | 遥感影像拼接
  13. Gradle实现多渠道打包(不同资源文件打不同的包)
  14. 51单片机利用STC-ISP下载软件时串口打开失败怎么办?
  15. 播放器实战08 打开AVCODEC
  16. 【国家集训队】middle
  17. java 编写线程公共类_Java实现线程间通信方式
  18. SVN如何本地拉取项目
  19. 补交20145226蓝墨云班课 -- Arrays和String单元测试
  20. 右键解决方案,没有“重定解决方案目标”这一菜单项

热门文章

  1. 1.2 微型计算机的分类
  2. 计算机服务代码怎么查,怎么查计算机服务代码
  3. oracle dblink用处,dblink的使用
  4. Android手机App安全漏洞整理
  5. U盘为RAW格式无法格式化问题解决办法
  6. 计算机打不开运行软件怎么回事,电脑上软件打不开怎么办(电脑无法运行任何程序)...
  7. 百度、搜狗、讯飞同时宣布语音识别准确率达到97%,他们是怎么做到的?
  8. 北京打工指南(转载)
  9. MockMvc简单使用
  10. 安卓轻量级数据库框架-GreenDao3.2.2集成方案