操作系统中的死锁问题

1 死锁问题概述

  • 一组阻塞的进程持有一种资源等待获取另一个进程所占有的一个资源.
  • 例子: 系统有两个磁带驱动器, P1和P2各有一个, 都需要另外一个.

2 系统模型

资源类型:

R_{1}R_{2}, ...R_{m}, 包括CPU cycles, memory space, I/O devices

每个资源类型R_{i}W_{i}实例.

每个进程使用资源过程如下:

  1. request/get <-- free resource
  2. use/hold     <-- requested/used resource
  3. release       <-- free resource

可重复使用的资源:

  • 在一个时间只能一个进程使用且不能被删除
  • 进程获取资源, 后来释放由其他进程重用
  • 处理器, I/O通道, 主和副存储器, 设备和数据结构, 如文件, 数据库和信号量
  • 如果每个进程拥有一个资源并请求其它资源, 死锁可能发生

使用资源:

  • 创建和销毁
  • 在I/O缓冲区的中断. 信号, 消息, 信息
  • 如果接收消息阻塞可能会发生死锁
  • 可能少见的组合事件会引起死锁

2.1 资源分配图

资源分配图:

一组顶点V和边E的集合:

  • V

其中V有两种类型:

  • P = \{P_{1}, P_{2}, ..., P_{n}\}, 集合包含系统中所有的进程.
  • R = \{R_{1}, R_{2}, ..., R_{n}\}, 集合包含系统中所有的资源类型.
  • E
  • requesting/claiming edge - directed edge P_{i}->R_{j}
  • assignment/holding edge - directed edge R_{j}->P_{i}

2.2 资源分配图举例

 

  • 图中有四种类型的资源:  R_{1}, R_{2}, R_{3}, R_{4}(图中的四个方格), R_{1}有一个资源实例可供使用(方格中的小圆), R_{2}有两个,  R_{3}有一个, R_{4}有三个
  • 图中有三个进程: P_{1}, P_{2}, P_{3}(图中的三个大圆圈)
  • 有四个资源正在被占用: R_{1}中的一个正在被P_{2}占用, R_{2}中的一个正在被P_{1}占用, 另一个正在被P_{2}占用, R_{3}中的一个正在被P_{3}占用
  • 有两个资源申请: P_{1}申请R_{1}P_{2}申请R_{3}

此时的情况是:

  • P_{1}: 正在申请R_{1}, 但是R_{1}的唯一资源实例被P_{2}占用, 等待中
  • P_{2}: 正在申请R_{3}, 但是R_{3}的唯一资源实例被P_{3}占用, 等待中
  • P_{3}: 正在运行中

并不会出现死锁情况, 因为P_{3}使用完R_{3}就会释放, P_{2}就会拿到R_{3}P_{2}使用完R_{1}R_{2}R_{3}会对其进行释放, P_{1}就会拿到R_{1}继续运行, 最终所有进程顺利执行完毕.

如果此时P_{3}未使用完R_{3}时申请了R_{2}, 如图:

此时就会有死锁, 此时有两个环:

  • P_{1}->R_{1}->P_{2}->R_{3}->P_{3}->R_{2}->P_{1}
  • P_{2}->R_{3}->P_{3}->R_{2}->P_{2}

通过以上例子可以看出, 当出现死锁情况时, 资源分配图中一定是有环的, 但是资源分配图中有环时并不一定会出现死锁情况, 例子如下:

 此时存在环P_{1}->R_{1}->P_{3}->R_{2}->P_{1}, 但是并不会出现死锁, 因为P_{2}P_{4}并没有依赖, 所以其占用的资源最终会释放, 从而其他进程可以顺利拿到需要的资源并执行.

2.3 基本情况

  1. 如果资源分配图中不包含循环, 那么就不会出现死锁

  2. 如果图中包含循环:

  • 如果每个资源类只有一个实例, 那么就会死锁
  • 如果每个资源类有几个实例, 那么不一定会死锁

3 死锁特征

死锁出现需要以下四个条件:

  • 互斥: 在一个时间只能有一个进程使用资源
  • 持有并等待: 进程保持至少一个资源正在等待获取其他进程持有的额外资源
  • 无抢占: 一个资源只能被进程自愿释放, 进程已经完成了它的任务之后.
  • 循环等待: 存在等待进程集合\{P_{0}, P_{1}, P_{2}, ..., P_{n}\}P_{0}正在等待P_{1}所占用的资源, P_{1}正在等待P_{2}所占用的资源, ..., P_{n - 1}正在等待P_{n}所占用的资源, P_{n}正在等待P_{0}所占用的资源.

以上四个条件为死锁出现的必要非充分条件.

4 死锁处理方法

  • 确保系统永远不会进入死锁状态
  • 运行系统进入死锁状态, 然后恢复
  • 忽略这个问题, 假装系统中从来没有发生死锁. 用于大多数操作系统, 包括UNIX.

原因(忽略死锁问题):

  • 判断死锁问题出现的开销很大
  • 预防死锁会限制操作系统的能力

4.1 Deadlock Prevention

Deadlock Prevention也就是死锁预防. 因为前文讲到, 死锁出现的四个条件为:

  • 互斥
  • 持有并等待
  • 无抢占
  • 循环等待

如果有其中一个条件不满足, 死锁也就不会出现.

针对每一个条件的解决方法:

  • 互斥: 共享资源不是必须的, 必须占用非共享资源
  • 占用并等待: 必须保证当一个进程请求的资源, 它不持有任何其他资源.
  • 需要进程请求并分配其所有资源, 它开始执行之前或允许进程请求资源仅当进程没有资源
  • 资源利用率低, 可能发生饥饿.
  • 无抢占
  • 如果进程占有某些资源, 并请求其它不能被立即分配的资源, 则释放当前正占有的资源
  • 被抢占的资源添加到资源列表中
  • 只有当它获得旧的资源以及它请求新的资源, 进程可以得到执行 
  • 循环等待: 对所有资源类型进行排序, 并要求每个进程按资源的顺序进行申请 

4.2 Deadlock Avoidance

Deadlock Avoidance也就是死锁避免, 需要系统具有一些额外的先验信息提供:

  • 最简单和最有效的模式是要求每个进程声明它可能需要的每个类型资源的最大数目
  • 资源的分配状态是通过限定提供与分配的资源数量, 和进程的最大需求
  • 死锁避免算法动态检查的资源分配状态, 以确保永远不会有一个环形等待状态

当一个进程请求可用资源, 系统必须判断立即分配是否能使系统处于安全状态. 系统处于安全状态指: 针对所有进程, 存在安全序列:

安全状态:

  • 序列<P_{1}, P_{2}, ..., P_{n}>是安全的: 针对每个P_{i}P_{i}要求的资源能够由当前可用的资源 + 所有的P_{j}持有的资源来满足, 其中j < i.
  • 如果P_{i}资源的需求不是立即可用, 那么P_{i}可以等到所有P_{j}完成.
  • P_{i}完成后, P_{i + 1}可以得到所需要的资源, 执行, 返回所分配的资源, 并终止.
  • 用同样的方法, P_{i + 2}P_{i + 3}P_{n}能获得其所需的资源.

如果系统处于安全状态, 那么肯定没有死锁, 如果系统处于不安全状态, 那么可能会死锁. 避免死锁, 也就是确保系统永远不会进入不安全状态, 比如银行家算法.

4.3 Deadlock Detection

Deadlock Detection也就是死锁检测:

  • 允许系统进入死锁状态
  • 死锁检测算法
  • 恢复机制

检测方法:

  • 每个资源类型单一实例

把资源分配图简化, 把资源节点都去掉, 只留下进程节点, 如果某一个进程需要一个资源且需要的资源被另一个进程拥有, 那么就直接建立两个进程的连线, 并判断整个图是否有环

  • 资源类型的几个实例

 1. 与安全判断算法(银行家算法)类似, 设置以下:

  • Available: 长度为M的向量表示每种类型可用资源的数量
  • Allocation: 一个n * m的矩阵定义了当前分配给各个进程每种类型资源的数量
  • Request: 一个n * m矩阵表示各进程的当前请求, 如果Request[i, j] = k, 表示进程P_{i}请求k个资源R_{j}的实例.

2. 初始化:

  • Work = Available                          //Work为当前空闲资源量
  • Finish[i]表示线程是否结束

3. 找出这样的索引i:

  • Finish[i] = false
  • Request_{i} \leq Work                              //线程没有结束的线程, 且此线程将需要的资源量小于当前空闲资源量, 如果没有找到, 跳到第四步

4. 如果找不到可以直接结束的线程, 表示处于死锁状态

算法复杂度:

O(m * n^{2}), 开销较大

检测算法使用时机:

  • 依赖于死锁多久可能会发生, 多少进程需要被回滚
  • 如果检测算法多次被调用, 有可能是资源图有多个循环, 所以我们无法分辨出多个可能死锁进程中的哪些"造成"死锁 

4.4 Recovery from Deadlock

Recovery from Deadlock也就是死锁恢复

如果发现系统有死锁状态, 有以下处理方式:

  • 终止所有的死锁进程
  • 在一个时间内终止一个进程直到死锁消除

终止进程的顺序应该是:

  • 进程的优先级
  • 进程运行了多久以及需要多少时间才能完成
  • 进程占用的资源
  • 进程完成需要的资源
  • 多少进程需要被终止
  • 进程是交互还是批处理
  •  资源抢占
  • 选择一个受害者 -- 最小的成本
  • 回滚 -- 返回到一些安全状态, 重启进程到安全状态
  • 饥饿 -- 同一进程可能一直被选做受害者, 包括回滚的数量

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/505394.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

chrome控制台如何把vw显示成px_你可能不知道的chrome调试技巧

本文是对常用的chrome调试技巧进行总结整理&#xff0c;如果你没有深入了解过chrome调试工具&#xff0c;此处总有你不知道的惊喜&#xff01;从 Chrome 说起对于大部分人来说&#xff0c;Chrome 可能只是个浏览器&#xff0c;但是对于开发人员来说&#xff0c;它更是一个强大无…

gns3中两个路由器分别连接主机然后分析ip数据转发报文arp协议_ARP协议在同网段及跨网段下的工作原理...

前言&#xff1a;ARP协议是在链路层通讯中&#xff0c;已知目标IP地址,但是&#xff0c;仅有IP 地址是不够的&#xff0c;因为IP数据报必须封装成帧才能通过数据链路进行发送&#xff0c;而数据帧必须要有目的MAC地址&#xff0c;每一个网络设备在数据封装前都需要获取下一跳的…

操作系统文件系统

1 基本概念 1.1 文件系统和文件 1.1.1 简述 文件系统: 一种用于持久性存储的系统抽象 在存储器上: 组织, 控制, 导航, 访问和检索数据大多数计算机系统包含文件系统个人电脑, 服务器, 笔记本电脑ipod, Tivo/机顶盒, 手机/掌上电脑google可能是由一个文件系统构成的 文件: 文…

c++代码整洁之道pdf_别再问如何用python提取PDF内容了

作者&#xff1a;陈熹 来源&#xff1a;早起Python大家好&#xff0c;在之前的办公自动化系列文章中我们已经详细介绍了如何使用python批量处理PDF文件&#xff0c;包括合并、拆分、水印、加密等操作。今天我们再次回到PDF&#xff0c;详细讲解如何使用python从PDF提取指定的信…

查看文章影响因子的插件_Scholarscope--在新版PubMed中实现基于影响因子的文献筛选...

小编之前介绍过如何在Pubmed上直接显示杂志影响因子的方法&#xff0c;这个方法主要是依托Scholarscope插件&#xff0c;其实除了显示影响因子&#xff0c;这个插件还可以帮助大家根据影响因子筛选文献哦&#xff0c;操作也很简单&#xff0c;只要生成自定义过滤器即可&#xf…

leetcode32 --- longestValidParentheses

1 题目 给你一个只包含 ( 和 ) 的字符串&#xff0c;找出最长有效&#xff08;格式正确且连续&#xff09;括号子串的长度。 2 解法 2.1 动态规划方法 维护一个字符串长度的数组cur_max_len, 第i个元素代表以当前(或者)结束的最长有效括号的长度. 这样就会利用动态规划递推…

armitage识别不了漏洞_Shiro RememberMe 漏洞检测的探索之路

前言Shiro 是 Apache 旗下的一个用于权限管理的开源框架&#xff0c;提供开箱即用的身份验证、授权、密码套件和会话管理等功能。该框架在 2016 年报出了一个著名的漏洞——Shiro-550&#xff0c;即 RememberMe 反序列化漏洞。4年过去了&#xff0c;该漏洞不但没有沉没在漏洞的…

css响应式布局_用 CSS Grid 布局制作一个响应式柱状图

最新一段时间比较喜欢玩弄图表&#xff0c;出于好奇&#xff0c;我想找出比较好的用 CSS 制作图表的方案。开始学习网上开源图表库&#xff0c;它对我学习新的和不熟悉的前端技术很有帮助&#xff0c;比如这个&#xff1a;CSS Grid。今天和大家分享我学到的新知识&#xff1a;如…

vs code 插件_[VSCode插件开发] 由浅入深,带你了解如何打造百万级产品

去年&#xff0c;笔者有幸在微软技术暨生态大会上做了个演讲&#xff0c;主题是“从零开始开发一款属于你的 Visual Studio Code 插件”。演讲内容主要覆盖了VS Code插件开发的四个方面&#xff1a;设计、实现、推广和维护。作为一个开发者&#xff0c;我们往往会把大多数的时间…

leetcode45 --- jump

1 题目 给定一个非负整数数组&#xff0c;你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 你的目标是使用最少的跳跃次数到达数组的最后一个位置。 假设你总是可以到达数组的最后一个位置。 2 解法 2.1 从终点遍历的方法(时间复杂度)…

python怎么查看网页编码格式_怎么用python爬取网页文字?

用Python进行爬取网页文字的代码&#xff1a;#!/usr/bin/python# -*- coding: UTF-8 -*-import requestsimport re# 下载一个网页url htt用python进行爬取网页文字的代码&#xff1a;#!/usr/bin/python# -*- coding: UTF-8 -*-import requestsimport re# 下载一个网页url htt…

leetcode41 --- firstMissingPositive

1 题目 给你一个未排序的整数数组 nums &#xff0c;请你找出其中没有出现的最小的正整数。 请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。 2 解法 最笨的方法是从1开始试, 看1在数组里面是否出现过, 2, 3, ....不过时间复杂度是. 2.1 hash 可以考虑…

计算机网络中的数据链路层

概述 结点: 主机, 路由器 链路: 网络中两个结点之间的物理通道, 链路的传输介质主要有双绞线, 光纤和微波, 分为有线链路和无线链路. 数据链路: 网络中两个结点之间的逻辑通道, 把实现控制数据传输协议的硬件和软件加到链路上就构成数据链路. 帧: 链路层的协议数据单元…

jnativecpp.dll一定要放到系统目录下吗_电脑硬盘有必要分区吗,分几个区最好?...

购买电脑后&#xff0c;必不可少的一个步骤就是对电脑硬盘进行分区了&#xff0c;其实硬盘分区也是有讲究的&#xff0c;并不是随意分的&#xff0c;下面租物租就给大家介绍下电脑分区的知识。硬盘分区可以提高数据的安全&#xff0c;防止数据丢失&#xff0c;但是防止数据丢失…

数据结构中的树

1. 树 即是以层次化方式组织和存放数据的特定数据结构 边: 节点与节点之间的连线 根节点: 叶子节点: 度: 节点的度数即为其分叉数, 即其子节点个数. 整棵树的度数是所有节点中度数的最大值 节点深度: 根节点到该节点的唯一路径长(即边的数量) 树高: 所有节点中深度的最大…

排序算法 --- 堆排序

根据大顶堆的描述, 父节点的值始终大于子节点(如果有的话)的值, 再加上堆是完全二叉树, 可以用数组表示, 那么就可以用来进行排序. 具体做法就是, 对于随机排列的数组: 1. 首先将其构建成一个大顶堆, 根据堆的性质, 此时堆顶就是最大值. 2. 把堆顶元素与数组最后一个元素进行…

数据结构中的树 --- 红黑树

红黑树是一种几近平衡的二叉搜索树, 但不是AVL树. 1 红黑树的一些特殊性质 1. 每个节点皆为红色或者黑色。 2. 根节点是黑色。 3. 每个叶子节点&#xff08;NIL&#xff09;是黑色(注意, 每个叶子节点必须都为空节点, 也就是指针为nullptr, 无key值)。 4. 每个红色结点的两…

c++数据结构中 顺序队列的队首队尾_数据结构与算法—队列详解

前言栈和队列是一对好兄弟&#xff0c;前面我们介绍过数据结构与算法—栈详解&#xff0c;那么栈的机制相对简单&#xff0c;后入先出&#xff0c;就像进入一个狭小的山洞&#xff0c;山洞只有一个出口&#xff0c;只能后进先出(在外面的先出去)。而队列就好比是一个隧道&#…

phpstudy apache无法启动_phpstudy和wamp哪个好

刚刚接触php的同学会想知道phpstudy和wamp的区别有哪些&#xff1f;phpstudy和wamp哪个好&#xff1f;下面我们来总结一下。一&#xff1a;phpstudy好还是wamp好php的运行环境配置对于新手都是一件比较困难的事情&#xff0c;但是对于高手配置是一件繁琐的事情&#xff0c;个人…

哈夫曼树(最优二叉树)

1 用途 现在假如有一个需求, 把一个很长的字符串用二进制编码的形式存储, 要尽可能的占用较小空间, 那么应该怎么存储呢. 肯定是要确定每个字母的编码方法, 比如 001是A, 010是B等. 那么要怎么确定每个字符编成什么二进制码从而使得总长度最短? 一个根本思想是, 出现频率高的…