浅析死锁

什么是死锁?

  死锁就是两个或多个进程在执行的过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞现象,当进程处于这种状态时,如果没有外力的作用,这些进程都无法继续向前进行。这是操作系统层面的一个错误,是进程死锁的简称。

产生死锁的原因:

资源竞争

  系统中额资源分为可剥夺资源和不可剥夺资源。可剥夺资源指的是某进程在获得这类资源后,这份资源还可以继续被其他进程或者系统所获得,CPU和主存均属于可剥夺资源,比如说可以把一个进程从一个存储区移到另一个存储区。不可剥夺资源指的是系统把资源分配给某个进程后,就不能强行把这份资源收回,只能在该进程结束后自行释放,比如说一个进程正在使用打印机打印一份文件,这时如果要给这个打印机重新分配一个进程,那么打印出来的文件一定会受损,所以只能等这个进程结束了,自己释放这个打印机。
   通俗说:可剥夺资源就是你正在吃的馒头,当你刚拿起馒头时,一个比你彪悍的人和你要这个馒头,你就得给他。不可剥夺资源就是你已经吃进肚子里的馒头,这个彪悍的人想和你要这个已经吃了的馒头也要不到。
  产生死锁中有关资源竞争的其中一个就是竞争不可剥夺资源,就按上面的例子,当P1正在使用A打印机的时候,如果P2也要使用打印机A,那么打印机A就会阻塞
产生死锁中有关资源竞争的另一个就是竞争临时资源,这些临时资源一般有中断、信号、消息等,通常消息通信顺序进行不当时,就会产生死锁。

产生死锁的4个必要条件

1、互斥条件
2、请求与保持条件
3、不可剥夺条件
4、环路等待条件
互斥条件:在同一时刻只有一个线程可以操作
请求与保持条件:嘴里吃着馒头,还想要隔壁桌上的馒头,隔壁桌子上的馒头吃不着,自己的也不放
不可剥夺条件上面已经给出
环路等待条件:A拿着A的馒头去请求B的馒头,同时B又拿着B的馒头去请求A的馒头,这样就造成了一个环路

在这里插入图片描述

预防死锁:

  破坏四个必要条件中的一个或几个条件,易于实现,但会导致资源利用率和系统吞吐量降低,有效预防死锁的三个方案:
  a.舍弃“请求和保持”条件:要求所有的进程一次性申请完所需的全部资源,不出现资源等待
  b.舍弃“不剥夺”条件:如果进程已经保持了资源,如果他在提出新的资源要求并且不能立刻满足,这个进程就必须释放自己已经保持的所有资源,以后需要重新申请。
  c.舍弃“环路等待”条件:将资源进行分类并按顺序排列,所有进程请求资源时必须严格按照排列好的递增次序来进行,不出现环路情况。

避免死锁:

  可以采用银行家算法和死锁检测算法来避免产生死锁

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

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

相关文章

一篇文章搞懂数据仓库:三范式与反范式

少年易老学难成,一寸光阴不可轻。 目录 一、第一范式 二、第二范式 三、第三范式 四、反范式化 五、范式化设计和反范式化设计的优缺点 5.1 范式化 (时间换空间) 5.2 反范式化(空间换时间) 六、OLAP和OLTP中范…

2018年全球AI突破性技术TOP10

来源:艾瑞网摘要:聪明的科技公司都不再单一的专注于自己的传统业务,而是着眼于未来,不断创新技术,跨界融合打造一个整合的生态系统。人工智能是个高科技、宽领域、多维度、跨学科的集大成者,从立足大数据、…

Linux的发展

1. Linux发展史 说起Linux你可能要问Linux是从哪里来的?他是怎么发展的?   要想知道Linux,还得从UNIX说起。 1.1 UNIX发展的历史 1968年,一些来自通用电器公司、贝尔实验室和麻省理工学院的研究人员开发了一个名叫Multics的特殊…

Hbase rowkey设计原则,热点问题

rowKey的作用 读写数据时通过 RowKey 找到对应的 Region;MemStore 中的数据按 RowKey 字典顺序排序;HFile 中的数据按 RowKey 字典顺序排序。 rowkey设计原则 唯一性:类似于MySQL、Oracle中的主键,用于标示唯一的行;…

MEF: MSDN 杂志上的文章(15) 拒绝【多个导出,但只用一个导入,会拒绝,但还是稳定的组合】...

http://msdn.microsoft.com/zh-cn/magazine/ee291628.aspx转载于:https://www.cnblogs.com/Ken-Cai/archive/2012/06/22/2558978.html

全球11个行业、71家知名企业的创新Lab与布局

来源:CBInsights新技术的革新引发了商业世界重构的浪潮,在这一波由人工智能引领的创新潮流里唯有拥抱变化才能不为时代淘汰,顺应趋势取得更大的发展。新技术的革新引发了商业世界重构的浪潮,在这一波由人工智能引领的创新潮流里唯…

组队竞赛

题目解析: 队伍的水平值等于该队伍队员中第二高水平值,为了所有队伍的水平值总和最大的解法,也就是说每个队伍的第二个值是尽可能大的值。所以实际值把最大值放到最右边,最小是放到最左边。 解题思路: 本题的主要思路是…

【SD】差异值 生成 同一人物 制作 表情包 【1】

说明:只对AI生成的人物,效果稳定。 Reference差异值 生成表情 首先生成一张图片。 测试命令:1 man,chibi,full body, 模型:envyclarityxl02_v10.safetensors [f6c13197db] 种子:2704867166 》》测试命令&#xff1a…

MySQL索引原理、失效情况

声明:本文是小编在学习过程中,东拼西凑整理,如有雷同,纯属借鉴。 Mysql5.7的版本, InnoDB引擎 目录 1 mysql索引知识 1.1 BTree索引 1.2 主键索引和普通索引的区别 1.3 唯一索引vs普通索引 2 mysql索引优化 2.1 查看索引使…

2018年人工智能全景图与发展趋势分析

来源:专知摘要:风险资本家马特图尔克(Matt Turck)最近发布文章,能力越大,责任越大,介绍了大数据与人工智能在2018年发展的趋势,并发布了全景图,涵盖基础架构、开源框架、…

李晨 | 无人机市场浅析

来源:无人机作者简介:西北工业大学民用无人机研发中心副主任无人机市场浅析无人机市场分类过去无人机一直是军用为主,不论是伊拉克战争还是好莱坞大片,无人机在执行军事任务方面起到了不可替代的作用。在2010年以前,军…

[转载] 财经郎眼20120423:长点心吧“两桶油”!

转载于:https://www.cnblogs.com/6DAN_HUST/archive/2012/06/24/2559970.html

linux 监控网络IO、磁盘、CPU、内存

linux 监控网络IO、磁盘、CPU、内存 CPU:vmstat ,sar –u,top磁盘IO:iostat –xd,sar –d,top网络IO:iftop -n,ifstat,dstat –nt,sar -n DEV 2 3磁盘容量&a…

不要二

题目解析: 本题的重点是要读懂题意,并且需要多读两遍,才能读懂,本题本质就是在二维数组中每个坐标去放蛋糕, 一个坐标位置放了蛋糕,跟他欧几里得距离为2的位置不能放蛋糕,这个就是关键点。对于两…

干货|100张PPT讲透工业机器人的机械结构

来源:机电微学堂未来智能实验室是人工智能学家与科学院相关机构联合成立的人工智能,互联网和脑科学交叉研究机构。未来智能实验室的主要工作包括:建立AI智能系统智商评测体系,开展世界人工智能智商评测;开展互联网&…

现实生活中我们常常遭遇“怀疑”

现实生活中,我们常常遭遇这样的“怀疑”。“最美婆婆”陈贤妹打破路人冷漠出手相救女童,被人猜度为“想出名”;“最美司机”吴斌忍着剧痛完成了“最后的制动”,有人却质疑他违章在先才这么做;看到热心人帮扶摔倒的老人…

虚拟机磁盘扩容流程

磁盘扩容: 1.vgdisplay #查看vg 2.lvdisplay #查看需扩容目录的全名 3.df -h #查看lv 4.fdisk /dev/sdb 依次输入:n p 回车 回车 回车 w …

最低票价

题目: 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行。在接下来的一年里,你要旅行的日子将以一个名为 days 的数组给出。每一项是一个从 1 到 365 的整数。 火车票有三种不同的销售方式: 一张为期一天的通行证售价为…

基础理论研究是人工智能持续发展的保证

来源:图灵人工智能摘要: 人工智能的主流技术的发展大致经历了三个重要的历程。人工智能的主流技术的发展大致经历了三个重要的历程。1956-1965年,人工智能的形成期,强调推理的作用。一般认为只要机器被赋予逻辑推理能力就可以实现…

鼠标关机后仍然发光的实用解决方法

现在朋友们用的鼠标大多数都是光电鼠了,但是大家注意到这样一个现象没有呢?就是在正常关机以后鼠标仍然在继续发光而不会灭,为什么呢??如何才能解决这样的问题呢??下面就介绍一下“让鼠标在关机…