死锁问题全解答

死锁问题全解答

死锁是什么?

在多线程编程中,我们为了防止多线程竞争共享资源而导致数据错乱,都会在操作共享资源之前加上互斥锁,只有成功获得到锁的线程,才能操作共享资源,获取不到锁的线程就只能等待,直到锁被释放。

那么,当两个线程为了保护两个不同的共享资源而使用了两个互斥锁,那么这两个互斥锁应用不当的时候,可能会造成两个线程都在等待对方释放锁,在没有外力的作用下,这些线程会一直相互等待,就没办法继续运行,这种情况就是发生了死锁。

死锁的条件

  • 互斥条件:对于临界资源,只能独享
  • 持有并等待:在等待其他资源的时候,并不会放弃自己持有的锁
  • 不可剥夺:当线程已经持有资源时,如果自己不释放资源占用,别的线程无法剥夺其使用权
  • 环路等待:两个线程获取资源的顺序构成了环形链

避免死锁问题的发生

根据死锁产生的四个必要条件,只需要破坏其中一个条件就可以

预防死锁:

  • 资源一次性分配
  • 使资源可剥夺
  • 资源有序分配

避免死锁:
在资源分配过程中,使用某种方法避免系统进入不安全的状态,从而避免发生死锁,例如银行家算法

检测死锁:
我们可以建立一个有向图:(类似二分图)

如果a持有b资源,那么从A向B构造一个有向边,如果a要使用b资源,b向a构造一个有向边,如果这个图出现了一个环,那么二分图构造失败,会发生死锁

解除死锁:
当发现有进程死锁后,便应立即把它从死锁状态中解脱出来,常采用的方法有:

  • 剥夺资源
  • 撤销进程
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

踢足球的程序员·

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值