C++面试总结之操作系统(三):死锁

本文探讨了死锁的概念,分析了死锁产生的原因及四个必要条件,并介绍了死锁预防的静态策略和动态避免策略,如资源预先分配、资源有序分配、银行家算法等,以及死锁检测与恢复的方法,包括进程回退和资源剥夺等解决方案。
摘要由CSDN通过智能技术生成

死锁、死锁 产生的条件、怎么处理死锁、怎么预防死锁

死锁:在两个或者多个并发进程中,如果每个进程持有某种资源而又等待其它进程释放它或它们现在保持着的资源,在未改变这种状态之前都不能向前推进,称这一组进程产生了死锁。通俗的讲就是两个或多个进程无限期的阻塞、相互等待的一种状态。

1. 产生死锁的原因主要:

(1) 因为系统资源不足。
(2) 进程运行推进的顺序不合适。
(3) 资源分配不当等。

2. 死锁的必要条件: 

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

3. 解决死锁的方法分为死锁的预防,避免,检测与恢复三种,当然还一种是忽略该问题例如鸵鸟算法,该算法可以应用在极少发生死锁的情况下。

(1)死锁的预防(静态)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值