解决死锁的方法

感情生疏 2个月前 已收到1个回答 举报

请别再犹豫 4星

共回答了41个问题采纳率:98.9% 评论

一、解除死锁常常采用两种方法:1、资源剥夺法;2、撤消进程法。

二、处理死锁的思路如下:

预防死锁:破坏四个必要条件中的一个或多个来预防死锁。

避免死锁:在资源动态分配的过程中,用某种方式防止系统进入不安全的状态。

检测死锁:运行时产生死锁,及时发现思索,将程序解脱出来。

解除死锁:发生死锁后,撤销进程,回收资源,分配给正在阻塞状态的进程。

三、预防死锁的办法:

破坏请求和保持条件:

1、一次性的申请所有资源。之后不在申请资源,如果不满足资源条件则得不到资源分配。

2、只获得初期资源运行,之后将运行完的资源释放,请求新的资源。

破坏不可抢占条件:当一个进程获得某种不可抢占资源,提出新的资源申请,若不能满足,则释放所有资源,以后需要,再次重新申请。

破坏循环等待条件:对资源进行排号,按照序号递增的顺序请求资源。若进程获得序号高的资源想要获取序号低的资源,就需要先释放序号高的资源。

扩展资料

形成死锁的四个必要条件:

(1) 互斥条件:一个资源每次只能被一个进程使用。

(2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。

(3) 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。

(4) 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

21小时前

34
可能相似的问题

热门问题推荐

Copyright © 2024 微短问答 All rights reserved. 粤ICP备2021119249号 站务邮箱 service@wdace.com