面试中常被问到的(15)死锁发生及解决

死锁是指多个进程因争夺资源而造成的一种僵局,彼此都无法继续执行。四个必要条件包括互斥、请求与保持、不可抢占和循环等待。解决死锁的方法包括一次性分配资源、可剥夺资源和资源有序分配,旨在破坏这些条件以避免死锁的发生。通过合理分配和管理资源,可以有效预防和解决操作系统中可能出现的死锁问题。
摘要由CSDN通过智能技术生成

首先要明白什么是死锁?

死锁:多个进程或线程访问一组竞态资源的时候,出现永久阻塞的问题

  • 死锁发生条件:

  1. 互斥:进程对所分配的资源不允许其他进程访问,若被其他进程访问,只能等待直至占用该资源的进程使用完成后释放该资源
  2. 请求与保持:进程获得一定资源后,又对其他资源发起请求,但是请求资源可能被其他线程占用,此时请求阻塞,与此同时该线程也不会释放自己已经占用的资源
  3. 不可抢占:进程已获得的资源在未使用完成之前,不可以被其他线程抢占剥夺,只能在自己使用完成后自己释放资源
  4. 循环等待:进程死锁后,必然存在进程与资源之间的环形链

总结:系统资源不足,程序运行推进顺序不当,资源分配不当

  • 死锁解决:

主要就是破坏上述死锁发生条件

方法一:通过资源一次性分配,破坏请求与保持条件

如果某个进程需要申请多个资源,只要有一个资源被其他线程占用不空闲,则暂时不分配资源,直至所有资源空闲可用时再统一分配

方法二:可剥夺资源,破坏不可抢占条件

如果一个进程请求多个资源,其中一个资源被其他线程占用不空闲,无法获取到该资源,则释放已获得的资源,方便后续进程可以请求资源,  即非阻塞加锁,若加锁失败则将已有锁释放

方法三:资源有序分配,破坏环路等待条件

系统给每类资源赋予一个序号,每个进程按编号递增的请求资源,释放则相反,始终在获取资源上有先后顺序

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

HT . WANG

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

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

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

打赏作者

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

抵扣说明:

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

余额充值