死锁、死锁 产生的条件、怎么处理死锁、怎么预防死锁
死锁:在两个或者多个并发进程中,如果每个进程持有某种资源而又等待其它进程释放它或它们现在保持着的资源,在未改变这种状态之前都不能向前推进,称这一组进程产生了死锁。通俗的讲就是两个或多个进程无限期的阻塞、相互等待的一种状态。
1. 产生死锁的原因主要:
(1) 因为系统资源不足。
(2) 进程运行推进的顺序不合适。
(3) 资源分配不当等。
2. 死锁的必要条件:
(1)互斥条件:一个资源一次只能被一个进程使用
(2)请求与保持条件:一个进程因请求资源而阻塞时,对已获得资源保持不放
(3)不剥夺条件:进程获得的资源,在未完全使用完之前,不能强行剥夺
(4)循环等待条件:若干进程之间形成一种头尾相接的环形等待资源关系
3. 解决死锁的方法:分为死锁的预防,避免,检测与恢复三种,当然还一种是忽略该问题,例如鸵鸟算法,该算法可以应用在极少发生死锁的情况下。
(1)死锁的预防(静态)