死锁相关知识
作者:互联网
一,什么是死锁?
死锁是指多个进程在运行过程中因争夺资源而造成的一种僵局,
此时若无外力作用,它们都将无法再向前推进。
例如:线程A,先锁a再获得锁b的顺序获得锁,
线程B,先锁b再获得锁a的顺序获得锁。
===============================================
二,产生死锁的原因?
1.竞争资源。
2.进程间推进顺序非法。
系统中的资源可以分为两类:可剥夺资源,不可剥夺资源。
可剥夺资源:CPU和内存。
不可剥夺资源:磁带机、打印机。
===============================================
三,死锁产生的4个必要条件?
1.互斥条件:
进程要求对所分配的资源进行排它性控制,即在一段时间内,
某资源仅为一进程所占用。
2.请求和保持条件:
当进程因请求资源而阻塞时,对已获得的资源保持不放。
3.不剥夺条件:
进程的资源在未使用完之前不能剥夺,只能在使用完时自己释放。
4.环路等待条件:
在发生死锁时,必然存在一个进程--资源的环形链。
===============================================
四,解决死锁的基本方法。
预防死锁:
1、以确定的顺序获得锁。
2、超时放弃。
避免死锁:银行家算法。
检测死锁:
1.首先为每个进程和每个资源指定一个唯一的号码;
2.然后建立资源分配表和进程等待表。
解除死锁:
1.剥夺资源。
2.撤消进程。
===============================================
标签:顺序,知识,获得,死锁,剥夺,进程,相关,资源 来源: https://blog.csdn.net/abc1641211976/article/details/121990573