Linux -- 死锁、自旋锁

目录

死锁

概念

死锁的四个必要条件

避免死锁的发生

自旋锁

概念

pthread_spin_init(初始化自旋锁)

pthread_spin_lock(申请自旋锁)

pthread_spin_unlock(释放自旋锁)

pthread_spin_destroy(销毁自旋锁)


死锁

概念

死锁(Deadlock)是指两个或多个进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,这些进程将无法继续推进。

举例来说,现在有线程 A 和线程 B,这两个线程都需要同时持有互斥锁 1 和互斥锁 2 才可以向后推进,访问临界资源,此时 线程 A 拿到了互斥锁 1,线程 B 拿到了互斥锁 2,两个线程都申请对方持有的锁,但是谁都不肯释放锁,导致谁都无法同时持有两把锁,那么这两个线程就互相等待,都不向后推进了,导致死锁!

死锁的四个必要条件

  1. 互斥条件:一个资源每次只能被一个执行流使用。
  2. 占有并等待条件:一个进程必须已经持有至少一个资源,并等待获取当前被其他进程占用的额外资源。
  3. 不可剥夺条件:资源不能从进程那里强行夺取,只有拥有该资源的进程可以主动释放资源。
  4. 循环等待条件:若干执行流之间形成一种头尾相连的循环等待资源的关系。即存在一组等待的进程{P1, P2, ..., PN},其中每个Pi正在等待由Pi+1持有的资源,PN等待由P1持有的资源。

避免死锁的发生

  • 只要破坏死锁的四个必要条件之一,就可以避免死锁!
  • 尽量缩短持有锁的时间,只在绝对必要的时候才获取锁,并尽快释放。
  • 确保所有线程总是按照相同的顺序获取锁,以防止循环等待。
  • 要求每个进程在开始执行之前一次性申请所有需要的资源。这种方法可以完全避免死锁,但可能导致资源利用率低下。

自旋锁

概念

自旋锁(Spinlock)是一种同步机制,主要用于多处理器系统中保护共享资源。与传统的互斥锁不同,当一个线程尝试获取已经被占用的自旋锁时,它不会立即进入睡眠状态(阻塞),而是会不停地循环检查锁的状态(忙等待或自旋),直到锁被释放。这种方式可以减少上下文切换带来的开销,但在锁持有时间较长的情况下,可能会浪费大量的CPU周期。

自旋锁最适合用于锁持有时间非常短暂的情形,例如保护少量数据或执行简单操作时。在这些情况下,上下文切换的成本可能超过自旋等待的成本。此外,在实时系统中,为了确保响应时间尽可能短,也常常使用自旋锁。

pthread_spin_init(初始化自旋锁)

#include <pthread.h>int pthread_spin_init(pthread_spinlock_t *lock, int pshared);

lock:指向要初始化的自旋锁对象的指针

pshared:指示该自旋锁是否可以在进程间共享。取值有两种:

  • PTHREAD_PROCESS_PRIVATE (0):默认值,表示该锁只能被同一进程内的线程共享
  • PTHREAD_PROCESS_SHARED (非0):表示该锁可以被多个进程中的线程共享。

返回值

  • 成功时返回 0
  • 如果发生错误,则返回一个正整数错误码,并且不会初始化自旋锁。

pthread_spin_lock(申请自旋锁)

#include <pthread.h>int pthread_spin_lock(pthread_spinlock_t *lock);

lock: 指向要获取的自旋锁对象的指针。

返回值:

  • 成功时返回 0
  • 如果发生错误,则返回一个正整数错误码。

pthread_spin_unlock(释放自旋锁)

#include <pthread.h>int pthread_spin_unlock(pthread_spinlock_t *lock);

 lock: 指向要释放的自旋锁对象的指针。

返回值:

  • 成功时返回 0
  • 如果发生错误,则返回一个正整数错误码。

pthread_spin_destroy(销毁自旋锁)

#include <pthread.h>int pthread_spin_destroy(pthread_spinlock_t *lock);

lock: 指向要销毁的自旋锁对象的指针。

返回值:

  • 成功时返回 0
  • 如果发生错误,则返回一个正整数错误码。

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

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

相关文章

YOLOv5部署到web端(flask+js简单易懂)

文章目录 前言最终实现效果图后端实现 主界面检测函数检测结果显示 前端实现 主界面(index.html&#xff09;显示图片界面 总结 前言 最近&#xff0c;老板让写一个程序把yolov5检测模型部署到web端&#xff0c;在网页直接进行目标检测。经过1个星期的努力&#xff0c;终于实…

基本算法——聚类

目录 创建工程 加载数据 聚类算法 评估 完整代码 结论 相比于有监督的分类器&#xff0c;聚类的目标是从一组未打标签的数据中识别相似对象组。它可 以用于识别同类群体的代表性样本&#xff0c;找到有用与合适的分组&#xff1b;或者找到不寻常的样本&#xff0c;比如 异…

安装教程:慧集通集成平台(DataLinkX)智能体客户端安装操作(Linux/windows/mac)

1.下载客户端 使用提供的账号登录集成平台后台(https://www.datalinkx.cn/),点击左侧菜单栏【智能体】→【智能体】进入到智能体列表界面&#xff0c;在该界面我们找到功能栏中的下载按钮点击则会弹出下载界面&#xff0c;在该界面我们可以选择不同的系统操作系统来下载对应版…

【Rust自学】8.4. String类型 Pt.2:字节、标量值、字形簇以及字符串的各类操作

8.4.0. 本章内容 第八章主要讲的是Rust中常见的集合。Rust中提供了很多集合类型的数据结构&#xff0c;这些集合可以包含很多值。但是第八章所讲的集合与数组和元组有所不同。 第八章中的集合是存储在堆内存上而非栈内存上的&#xff0c;这也意味着这些集合的数据大小无需在编…

1、pycharm、python下载与安装

1、去官网下载pycharm 官网&#xff1a;https://www.jetbrains.com/pycharm/download/?sectionwindows 2、在等待期间&#xff0c;去下载python 进入官网地址&#xff1a;https://www.python.org/downloads/windows/ 3、安装pycharm 桌面会出现快捷方式 4、安装python…

静默模式下安装Weblogic 14.1.1.0.0

目录 一、下载weblogic安装包二、安装JDK三、安装weblogic1、创建weblogic用户2、创建weblogic的安装目录3、上传并解压weblogic安装包4、创建 oraInst.loc 文件5、创建 wls.rsp 响应文件6、静默安装weblogic7、创建域8、启动Weblogic9、设置防火墙规则,以便其他服务器访问10、…

Windows安装Confluence详解

Confluence官网下载地址&#xff1a;https://www.atlassian.com/software/confluence/download-archives 建议安装confluence版本下载5.0-7.0之间&#xff0c;比较稳定一点&#xff0c;我安装的是6.8.2版本 centos7系统和阿里云服务安装后太卡了&#xff0c;果断放弃 Conflu…

Unity is running as administrator解决办法

每次打开Unity项目都会有这个弹窗 解决办法&#xff1a; 打开本地安全策略 - 安全选项 &#xff0c;把 用户账户控制&#xff1a;以管理员批准模式运行所有管理员 用户账户控制&#xff1a;用于内置管理员账户的管理员批准模式 改成已启用就行

springboot+vue实现SSE服务器发送事件

思路 一个基于订阅发布机制的SSE事件。客户端可以请求订阅api&#xff08;携带客户端id&#xff09;&#xff0c;与服务器建立SSE链接&#xff1b;后续服务器需要推送消息到客户端时&#xff0c;再根据客户端id从已建立链接的会话中找到目标客户端&#xff0c;将消息推送出去。…

【阻塞队列】- ArrayBlockingQueue 的原理-迭代器

文章目录 1. 前言2. 迭代器3. Itrs3.1 参数3.2 迭代器 Itr3.2.1 参数3.2.2 构造器3.2.3 hasNext3.2.4 next3.2.5 remove3.2.6 shutdown3.2.7 removedAt3.2.8 takeIndexWrapped 3.3 doSomeSweeping&#xff08;tryHandler&#xff09;3.4 register3.5 takeIndexWrapped3.6 remov…

人工智能与传统编程的主要区别是什么?

传统编程&#xff1a;开发者预先编写软件行为规则&#xff0c;代码基于程序员定义逻辑处理输入并产生确定输出&#xff0c;具有确定性、手动编写规则和结构化逻辑特点&#xff0c;如垃圾邮件分类程序基于预设关键词等规则。AI 编程&#xff1a;从数据中学习而非手动编写规则&am…

SpringBoot使用TraceId日志链路追踪

项目场景&#xff1a; ??有时候一个业务调用链场景&#xff0c;很长&#xff0c;调了各种各样的方法&#xff0c;看日志的时候&#xff0c;各个接口的日志穿插&#xff0c;确实让人头大。为了解决这个痛点&#xff0c;就使用了TraceId&#xff0c;根据TraceId关键字进入服务…

ts总结一下

ts基础应用 /*** 泛型工具类型*/ interface IProps {id: string;title: string;children: number[]; } type omita Omit<IProps, id | title>; const omitaA: omita {children: [1] }; type picka Pick<IProps, id | title>; const pickaA: picka {id: ,title…

八大排序——直接插入排序

直接插入排序&#xff08;Straight Insertion Sort&#xff09;&#xff0c;通常简称为插入排序&#xff0c;是一种简单直观的排序算法。它的工作原理是通过构建有序序列&#xff0c;对于未排序数据&#xff0c;在已排序序列中从后向前扫描&#xff0c;找到相应位置并插入。本文…

【QGIS入门实战精品教程】7.3:QGIS制作千层饼(DEM+等高线+影像+TIN)

文章目录 一、效果展示二、数据准备三、制作过程1. 打开软件2. 添加图层3. 制作千层饼一、效果展示 二、数据准备 订阅专栏后,从专栏配套案例数据包中的7.3.rar中获取。 1. dem 2. 影像 3. 等高线 4. tin 三、制作过程 1. 打开软件 打开QGIS软件。 QGIS软件主界面。

NetSuite Formula(HTML)超链打开Transaction

当Saved Search作为Sublist应用在Form时&#xff0c;如果Document Number是Group过的&#xff0c;则会出现如下超链失效的情况。 解决办法&#xff1a; 可以利用Saved Search中的Formula&#xff08;HTML&#xff09;功能来构建超链&#xff0c;用于打开Transaction。 以下图…

Springboot3.x整合swagger3

在网上看了许多教程&#xff0c;发现很多都是针对Spring Boot 2 框架的&#xff0c;即使有针对Spring Boot 3 的&#xff0c;用法也不太一样,配置项经常找不到类&#xff0c;经过对比测试&#xff0c;最后我使用的是 SpringDoc OpenAPI Starter WebMvc UI. pom为 <!--swag…

android.enableJetifier=true的作用:V4包的类自动编程成了androidx包的类,实现androidx的向下兼容

结论&#xff1a;引入androidx包后&#xff0c;可以兼容旧版本v4包的插件&#xff0c;把之前的 implementation com.yinglan.alphatabs:library:1.0.8 引入的组件中使用v4包的类&#xff0c;里面V4包自动反编译成 androidx包的类 结论; ‌V4包的类自动编程成了androidx包的…

详解MySQL在Windows上的安装

目录 查看电脑上是否安装了MySQL 下载安装MySQL 打开MySQL官网&#xff0c;找到DOWNLOADS 然后往下翻&#xff0c;找到MySQL Community(GPL) Downloads>> 然后找到MySQL Community Server 然后下载&#xff0c;选择No thanks,just start my download. 然后双击进行…

excel操作

来源&#xff1a;B站默默亚 一、版本识别 特点&#xff1a;向后兼容&#xff1b;高版本可以打开低版本&#xff0c;低版本不可以打开高版本 工作中&#xff0c;给老板最低版本&#xff0c;即2003版本 二、文件的扩展名 三、excel页面