概念
一、什么是死锁
哲学家进程问题中,都在等待另外的哲学家放弃另一只筷子,造成了都不能用餐的现象,互相等待对方的资源
二、死锁、饥饿、死循环区别
三、死锁产生的条件
1、互斥条件
只有对互斥使用的资源的争抢才能导致死锁,像内存,扬声器之类的可以共享的资源并不会导致死锁的产生;
2、不可剥夺条件
进程在使用完这个资源的时候不能被其他的进程掠夺这个资源,只能主动的释放;
3、请求和保持条件
进程已经保持了至少一个资源,但是又提出了新的资源请求,而该资源又被其他资源所占用;
4、循环等待条件
类似于哲学家进餐问题的互相等待筷子;
死锁的处理策略
一、预防死锁
1、破坏互斥条件
2、破坏不剥夺条件
3、破坏请求和保持条件
如果需要一次性请求所有资源,如果A,B交替使用资源1和2这个时候C不能一次性的请求1和2两个资源,导致了C进程资源饿死;
4、破环循环等待条件
如果先使用打印机,后使用扫描仪,但是需要扫描仪的编号在打印机之前,这样申请了扫描仪之后并不能使用,造成了资源浪费,而且不同的操作系统之间,编号顺序有可能不同,导致了不同的系统需要重新写不同的调用顺序代码,造成了用户编程比较麻烦
二、避免死锁
1、什么是安全序列?
安全序列指的就是能够找到使得每个进程都能够顺利的安全访问的条件,系统就是安全状态;安全序列可能有多个;
2、银行家算法
三、死锁的检测和解除
类似于安全序列
死锁定理:如果某时刻系统的资源分配图是不可以完全简化的,不能消除所有的边,导致系统死锁