【Linux】死锁(更新中)

news2024/12/28 3:44:01

文章目录

  • 一. 什么是死锁
  • 二. 死锁产生的四个条件
  • 三. 避免死锁
    • 1. 死锁检测算法
    • 2. 银行家算法
  • 结束语

在这里插入图片描述

一. 什么是死锁

  • 死锁是指一组进程中的各个进程均占有不会释放的资源,但因互相申请被其他进程所占用的不会释放的资源,而处于一种永久等待的状态。

就像下图(图片来自网络)

在这里插入图片描述

第一种死锁是,线程A和线程B同时让线程C让路,但因为空间狭窄,并且两人都互补想让,所以一直处于等待状态
第二种死锁是,线程A和线程B互相阻塞,都抢夺路权,并且不相让自己的,所以处于等待状态

二. 死锁产生的四个条件

死锁产生的四个条件属于必要条件,即如果出现死锁,必然由这四种条件导致,不过反之,可能还出现第5,第6种情况,也导致死锁。

  1. 互斥条件: 一个资源每次只能被一个执行流使用
  2. 请求与保持条件: 一个执行流因请求资源而阻塞时,对已获得的资源保持不释放
  3. 循环等待条件: 若干个执行流之间形成的一种头尾相接的循环等待资源的关系
  4. 不剥夺条件:一个执行流已获得的资源,在未使用完之前,不能被强行剥夺

三. 避免死锁

避免死锁的一种方法就是破坏上述的四个条件,只要破坏其中的任意一个,就不会产生死锁。

  • 对于互斥条件:我们可以尽量减少对临界资源的访问,减少加锁解锁的操作
  • 对于请求与保持条件:pthread_mutex_trylock函数,在多次加锁后,如果仍不成功,会解除自己所申请的锁。
  • 循环等待条件:使得加锁的顺序一致,比如两个线程都获取A,B两把锁。两个线程获取的顺序都是AB,减少交错的情况。如果一个线程AB,一个线程BA,那么一定会死锁。
  • 不剥夺条件:解锁操作允许其他线程进行,即可以剥夺资源。

还有一些其他方法:

  1. 避免锁未释放的场景
  2. 资源一次性分配

有两种常见的避免死锁的方法:

  1. 死锁检测算法
  2. 银行家算法

1. 死锁检测算法

死锁检测算法,首先需要一种数据结构来保存资源的请求和分配
其次是通过算法,利用请求和分配信息检测系统是否存在死锁

首先画图理解一下
在这里插入图片描述

如果系统中空闲的资源满足线程所需资源数量,那么该线程不会阻塞。
而当一个线程完成执行任务,将资源归还给操作系统,那么空闲的资源变多,可能使得一些本来因空闲资源不足而阻塞等待的线程被激活,开始执行任务。
以此类推,当最后所有线程都完成任务时,表面给程序没有死锁。
当一个线程可以完成任务时,我们可以在图中将其有向边消除。比如P1完成任务。

在这里插入图片描述
然后再P2完成任务
在这里插入图片描述

所有有向边消除,表面该程序没有死锁。


但如果是以下场景
在这里插入图片描述

R1分配2个资源给P1,分配1个资源给P2,R2分配1个资源给P2,但是此时,P2需要两个R1资源才能开始执行任务,P1需要两个R2资源才能执行任务,两个线程互相等待资源,但又不释放自己分配到的资源,导致死锁。

检测死锁的算法

在资源分配图中,找到既不阻塞又不是孤点的线程Pi(即找出一条有向边与它相连,且该有向边对应资源的申请数量小于等于系统中已有空闲资源数量。若所有链接该线程的有向边都满足次条件,那么该线程可以执行任务,然后归还资源。)

然后线程Pi归还的资源可能唤醒其他线程执行任务,当最后所有有向边都消除了,那么该程序没有死锁,反之,剩下的有向边是导致死锁的原因之一。


2. 银行家算法

后续补充

结束语

感谢你的阅读

如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。
在这里插入图片描述

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

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

相关文章

Elasticsearch是什么,如何学习Elasticsearch,整合SpringBoot

目录 一、是什么Elasticsearch 二、Elasticsearch,整合SpringBoot 三、Elasticsearch的优势和应用场景 一、是什么Elasticsearch Elasticsearch是一个开源的搜索引擎,它采用Java语言编写,使用Lucene作为核心搜索引擎,并在其基…

2.文本分析

目录 1. 词频统计--语料库的构建 1. 词频统计–语料库的构建 文本挖掘:将文本信息转换为可利用的知识。通常,对大量文件的归类,一般通过建立不同的文件夹,来保存不同的文章。 同样的,将需要分析的【文本文件】读取到…

Shell - 01_shell的概述

一、shell 概述 1.shell 的两层含义: 既是一种应用程序,又是一种程序设计语言 a.作为应用程序: 交互式地解释、执行用户输入的命令,将用户的操作翻译成机器可以识别的语言,完成相应功能。称之为 shell 命令解析器。shell 是用户和…

机器学习对风险管理的重要性

✏️写作:个人博客,InfoQ,掘金,知乎,CSDN 📧公众号:进击的Matrix 🚫特别声明:原创不易,未经授权不得转载或抄袭,如需转载可联系小编授权。 机器学…

logback-spring.xml详解

本文来写说下logback-spring.xml相关的知识与概念 文章目录 概述configuration元素定义上下文名称定义变量appender组件 概述 对于xml日志文件的配置,大多数人第一次接触时有一种望而生畏的感觉,其实如果仔细分析,会发现核心的部分只有三个元…

【黄啊码】为什么程序员大都鄙视php?

“PHP 是世界上最好的语言”。。。“吗”?相信很多人跟我一样,都会在后边打个问号。这些年以来,“PHP 已死”、“PHP 行将消亡”之类的言论甚嚣尘上,由此看得出,很多开发人员讨厌 PHP。这又是为什么呢?PHP …

Nginx配置https证书遇到的一个问题

前言 今天在给一个站点配置 HTTPS 证书的时候,遇到了一个问题,写此文章记录一下解决过程。 环境 Ubuntu 22.04 Nginx 1.18 过程 今天给一个站点申请了 HTTPS 证书,然后在 Nginx 中进行配置,Nginx 的 SSL 配置如下&#xff1a…

Matplotlib---饼图

1. 饼图 pie()函数用于绘制饼图,其基本语法如下: plt.pie(x, explodeNone, labelsNone, colorsNone, autopctNone, startangleNone, shadowFalse) 其中,参数含义如下: - x: 数组,表示饼图中每个部分的数值大小。 -…

手机技巧:iOS微信 8.0.38正式版更新功能一览

目录 1、安装包变大了很多 2、拍摄功能优化 3、订阅号消息展示优化 4、转账界面优化 5、视频号关注展开更多 7、朋友圈置顶(灰度测试) 8、搜一搜页面新增问一问功能 2023.06.09大家期待已久的IOS微信8.0.38正式版终于发布了,今天就来给…

第四章网络层

1.网络层概述 网络层的主要任务是实现网络互连,进而实现数据包在各网络之间的传输。 要实现网络层任务,需要解决以下主要问题: 网络层向运输层提供怎样的服务(“可靠传输”还是“不可靠传输”)网络层寻址问题路由选择问题 因特网(Internet)是目前全世界用…

idea快捷键和常用设置和maven

因为Eclipse快捷键较为统一,因此我们提前设置好,统一idea中的快捷键遵从Eclipse的快捷键。 常用设置 快捷键的统一 设置–按键映射–Eclipse 自动导包 设置–编辑器–常规–自动导入 这个操作主要是为了正确导包,当我们将某行代码注释的…

【物联网无线通信技术】LoRa从理论到实现(SX1268)

文章先从LoRa的物联网通信技术前辈们讲起,慢慢引出了这种功耗又低,距离又远的无线通信技术,然后又似庖丁解牛一般,从物理层到链路层,详细的介绍了LoRa这种技术的组成,最后以一种实际的原理与嵌入式软件实现…

MySQL实战解析底层---如何正确地显示随机消息

目录 前言 内存临时表 磁盘临时表 随机排序方法 前言 现在说说MySQL中的另外一种排序需求,希望能够加深对MySQL排序逻辑的理解从一个单词表中随机选出三个单词这个表的建表语句和初始数据的命令如下: 为了便于量化说明,在这个表里面插入…

ChatGPT科研阅读论文应用插件(txyz.ai)使用初探

前言 ChatGPT没有办法直接阅读论文,但使用txyz.ai插件可以使用ChatGPT来帮助快速得到论文中想要的信息,特别是对于专业名词较多的文章,而且可以问它关于这篇文章的问题,能够加快研究的进程。刚开始了解到这个应用是一个ChatGPT插件…

06- c语言指针 (C语言)

一 指针的引入 1、一般把内存中的一个字节称为一个内存单元。 2、为了正确地访问这些内存单元,必须为每个内存单元编上号。根据一个内存单元的编号即可准确地找到该内存单元。内存单元的编号也叫做地址,通常也把这个地址称为指针。 3、如果在程序中定义…

设计模式之策略模式笔记

设计模式之策略模式笔记 说明Strategy(策略)目录策略模式示例类图抽象策略类策略A类策略B类策略C类促销员类测试类 说明 记录下学习设计模式-策略模式的写法。JDK使用版本为1.8版本。 Strategy(策略) 意图:定义一系列的算法,把它们一个个封装起来,并且…

【数据分享】全国县市2000-2021年综合经济数据(地区生产总值\一二三产业增加值等)

《中国县域统计年鉴》是一部全面反映我国县域社会经济发展状况的资料性年鉴,收录了上一年度全国2000多个县域单位的基本情况、综合经济、农业、工业、教育、卫生、社会保障等方面的资料。 本篇文章我们给大家带来从2001年—2022年《中国县域统计年鉴》整理的数据—…

MySQL:事务

事务 在介绍事务之前,我们先来了解一个案例: 在一个买票的软件中,当客户端A检查还有一张票时,将票卖点,但是还没有更新数据库,客户端B检查了票数,发现大于0,于是又卖掉了一张票。然…

ROS:通信机制

目录 一、通信机制简介二、话题通信机制2.1话题通信简介2.2话题通信实操(C)2.2.1分析2.2.2发布方代码2.2.3订阅方代码2.2.4配置CMakeLists.txt2.2.5执行2.2.6注意 2.3话题通信实操(python)2.3.1分析2.3.2发布方代码2.3.3订阅方代码…

【计算机网络】第二章 物理层(上)

文章目录 2.1 物理层的基本概念2.2 物理层下面的传输媒体2.3 传输方式2.4 编码与调制2.4.1 介绍2.4.2 常用编码2.4.3 编码习题2.4.4 基本调制方法2.4.5 混合调制 2.1 物理层的基本概念 物理层考虑的是怎样在连接各种计算机的传输媒体上传输数据比特流。 物理层为数据链路层屏蔽…