怎样避免死锁和数据争夺
发布网友
发布时间:2022-05-06 03:31
我来回答
共1个回答
热心网友
时间:2022-05-12 10:04
事实上图灵已经证明死锁问题无法避免(当然包括数据争夺),只能尽可能地减小死锁的发生
死锁和数据争夺只能尽量避免
一般来说,如果系统资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。
另外死锁有4个必要条件(要发生缺一不可)
(1)
互斥条件:一个资源每次只能被一个进程使用。
(2)
请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
(3)
不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
(4)
循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
通过使用较好的资源分配算法,就可以尽可能地破坏死锁的必要条件,从而尽可能地避免死锁