【Linux】线程安全-死锁

这篇具有很好参考价值的文章主要介绍了【Linux】线程安全-死锁。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

死锁问题

死锁的两种场景:

场景1

线程加锁之后一直没有将锁释放,在上一篇文中,我们模拟过这种场景,某个线程拿到锁,进行加锁,线程退出之前没有释放锁,导致后面的线程不能拿到锁,一直在等待加锁,导致程序一直不退出,这也是为什么条件变量等待函数中第二个参数是锁的原因,在该函数内部,进行解锁,防止死锁

场景2

两个线程都想拥有对方的锁,导致死锁
【Linux】线程安全-死锁,Linux,linux

两个线程A和B都阻塞在自己的加锁逻辑当中去

代码如下:

执行结果:程序阻塞了,我们来分析一下

【Linux】线程安全-死锁,Linux,linux

【Linux】线程安全-死锁,Linux,linux

死锁的gdb调试

先使用gdb attach [pid]命令进入gdb调试状态

再使用 thread apply all bt来查看所有线程的调用堆栈

【Linux】线程安全-死锁,Linux,linux

t+线程序号=跳转到某个线程的调用堆栈当中

【Linux】线程安全-死锁,Linux,linux

我们如果想要进入某个具体的堆栈该怎么办呢?

f+[堆栈号]

【Linux】线程安全-死锁,Linux,linux

可以通过 p + [变量名]来打印这个变量,其中__owner表示锁被谁拿走了

【Linux】线程安全-死锁,Linux,linux
【Linux】线程安全-死锁,Linux,linux

对应我们的线程,可以看到,两个锁分别被两个线程持有,同时两个线程全部在等待拿锁,谁都想拿到对方的锁,但是谁也不可能解锁,所以谁都不可能拿到对方的锁,最后就造成死锁。

造成死锁的必要条件

不可剥夺

线程获取到互斥锁后,除非自己释放锁,不然其他线程是不可能进行锁的释放的

循环等待

上述场景2,线程A拿着1锁,请求2锁;线程B拿着2锁,请求1锁。

互斥条件

一个互斥锁,在同一时间只能被一个线程所拥有

请求和保持

吃着碗里的,看着锅里的,已经拿到一个锁,还想请求另一个锁,类似循环等待场景

预防死锁

破坏必要条件,循环等待&请求和保持

我们在加锁的时候可以用pthread_mutex_trylock()和pthread_mutex_timedlock( )函数,这样就能避免一直死等锁,尝试加锁多少次或者超时就放弃加速,让其他线程可以拿到锁

加锁顺序一致

【Linux】线程安全-死锁,Linux,linux

都先加一锁,再加二锁,这样防止一人拿一把锁,还继续等着拿第二把锁

避免锁没有被释放

在所有线程可能退出的地方都进行解锁

资源一次性分配

多个资源在代码当中有可能每一个资源都需要使用不同的锁进行保护
例如::使用全局变量A,需要1锁,用全局变量B,需要2锁
【Linux】线程安全-死锁,Linux,linux

就有可能多个线程在使用这两个资源的时候,出现循环等待的情况,解决方法:我们只需要给将A和B用同一把锁保护即可(资源一次性分配)文章来源地址https://www.toymoban.com/news/detail-690221.html

到了这里,关于【Linux】线程安全-死锁的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【JavaEE】多线程之线程安全(synchronized篇),死锁问题

    线程安全问题 观察线程不安全 线程安全问题的原因  从原子性入手解决线程安全问题 ——synchronized synchronized的使用方法  synchronized的互斥性和可重入性 死锁 死锁的三个典型情况  死锁的四个必要条件  破除死锁 在前面的章节中,我们也了解到多线程为我们的程序带来了

    2024年02月01日
    浏览(57)
  • 【Java-10】深入浅出线程安全、死锁、状态、通讯、线程池

    线程安全 线程死锁 线程的状态 线程间通讯 线程池 1.1 线程安全产生的原因 多个线程在对共享数据进行读改写的时候,可能导致的数据错乱就是线程的安全问题了 问题出现的原因 : 多个线程在对共享数据进行读改写的时候,可能导致的数据错乱就是线程的安全问题了 1.2 线程

    2024年02月11日
    浏览(72)
  • 【并发编程】多线程安全问题,如何避免死锁

    从今天开始阿Q将陆续更新 java并发编程专栏 ,期待您的订阅。 在系统学习线程之前,我们先来了解一下它的概念,与经常提到的进程做个对比,方便记忆。 线程和进程是操作系统中的两个重要概念,它们都代表了程序运行时的执行单位,它们的出现是为了更好地管理计算机

    2024年02月11日
    浏览(51)
  • 线程的深入理解(二):死锁和更多的并发安全(1)

    // Bug.addStatic();//静态方法同步 } } 测试代码 public static void main(String[] args) { BugRunnable bugRunnable = new BugRunnable(); for (int i = 0; i 6; i++) { new Thread(bugRunnable).start(); } } 同步代码块 //同步代码块 public synchronized void addBlock() { synchronized (bugNumber) { this.bugNumber = ++bugNumber; System.out.println(“b

    2024年04月11日
    浏览(43)
  • 【Linux】Linux 线程安全

    Linux 线程互斥 前置概念 临界资源: 多线程执行流共享的资源叫做临界资源 临界区: 每个线程内部,访问临界资源的代码,叫做临界区 互斥: 任何时刻,互斥保证有且只有一个执行流进入临界区,访问临界资源,保护临界资源 原子性:不会被任何调度机制打断的操作,该

    2024年02月12日
    浏览(30)
  • Linux线程安全

    临界资源 :多线程执行流共享的资源就叫做临界资源; 临界区 :每个线程内部,访问临界自娱的代码,就叫做临界区; 互斥 :任何时刻,互斥保证有且只有一个执行流进入临界区,访问临界资源,通常对临界资源起保护作用; 原子性 :不会被任何调度机制打断的操作,该

    2024年02月05日
    浏览(34)
  • 多线程基础入门【Linux之旅】——上篇【线程控制,线程互斥,线程安全】

    目录 前文 回望页表 一,什么是线程 二,使用 pthread_create (线程创建) 三,线程控制 1 ,线程共享进程数据,但也拥有自己的一部分数据: 2, 线程  VS 进程优点 3,pthread_join(等待线程) 4,pthread_exit (线程终止) 5, pthread_cancel (线程取消) 6. pthread_t 类型 7.  pthread_detac

    2024年01月16日
    浏览(53)
  • 【Linux】线程安全(万字详解)

    🎇Linux: 博客主页: 一起去看日落吗 分享博主的在Linux中学习到的知识和遇到的问题 博主的能力有限,出现错误希望大家不吝赐教 分享给大家一句我很喜欢的话: 看似不起波澜的日复一日,一定会在某一天让你看见坚持的意义,祝我们都能在鸡零狗碎里找到闪闪的快乐🌿

    2024年02月02日
    浏览(49)
  • Linux 可重入、异步信号安全和线程安全

    当一个被捕获的信号被一个进程处理时,进程执行的普通的指令序列会被一个信号处理器暂时地中断。它首先执行该信号处理程序中的指令。如果从信号处理程序返回(例如没有调用exit或longjmp),则继续执行在捕获到信号时进程正在执行的正常指令序列(这和当一个硬件中

    2024年02月11日
    浏览(34)
  • Linux之 线程池 | 单例模式的线程安全问题 | 其他锁

    目录 一、线程池 1、线程池 2、线程池代码 3、线程池的应用场景 二、单例模式的线程安全问题 1、线程池的单例模式 2、线程安全问题 三、其他锁 线程池是一种线程使用模式。线程池里面可以维护一些线程。 为什么要有线程池? 因为在我们使用线程去处理各种任务的时候,

    2024年04月18日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包