死锁的相关知识总结

本文深入探讨了死锁的概念,通过一个实例解释了死锁的产生。文章详细阐述了死锁的四个必要条件,包括互斥、请求和保持、不可抢占及循环等待。接着,介绍了预防死锁的三种策略,如破坏请求和保持、不可抢占及循环等待条件。此外,还讨论了避免死锁的银行家算法以及死锁的检测和解除方法,包括抢占资源和终止或撤销进程等策略。
摘要由CSDN通过智能技术生成

一、死锁

首先一个例子让我们理解死锁

假设有两个进程A和B,他们要求同时访问数据资源D和E,进程A先请求得到D资源,进程B先请求数据资源E并且申请成功,后来进程A又申请数据资源E,因为它已经被分配给了进程B而阻塞,进程B又申请数据资源D,因它被分配给了进程A而阻塞;双方都希望对方能释放自己所需要的资源,但他们因不能获得自己所需资源而继续运行,从而无法释放自己占有的资源,并且一直处于这样的僵持状态,这种状态称为死锁

1、死锁的定义

如果一组进程中的每一个进程都在等待仅由该组进程中的其他进程才能引发的事件,那么该进程是死锁的。

2、死锁的起因

(1)竞争不可抢占资源引起死锁
(2)竞争可消耗资源引起死锁
(3)进程推进顺序不当引起死锁

3、产生死锁的必要条件

(1)互斥条件:进程对所分配资源进行排它使用。
(2)请求和保持条件:进程已经保持了一个资源,但又提出了新的资源请求,而该新的资源已经被其他进程占有,此时请求进程被阻塞。
(3)不可抢占条件:进程已获得的资源在未使用完之前不能被抢占
(4)循环等待条件:在发生死锁时,必然存在一个进程——资源的循环链

二、死锁的处理方法

既然发生了死锁,那必然有对应的方法解决它ÿ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值