银行家算法(死锁避免)

注意死锁避免是在进程发出请求时进行判断,而死锁检测和死锁恢复是允许进入死锁状态,在运行时进行判断。 

 

 

银行家算法具体步骤:

 

但若是finish[i]存在false,且找不到满足true的状态了,就处于unsafe状态。

两个例子:如下图,当四个进程P1,P2,P3,P4都没结束,即finish[i]都为false,这时我们响应p2。

如上图,根据available矩阵,首先选择p2进程,如下图

p2结束后,将p2的allocation加到available里,如上图,此时仍为safe状态,并且下个进程执行可以有多种选择,但我们在这里选择p1,然后如下图

然后我们再选p3

 同理p4。这时我们就找到了一个序列:p2,p1,p3,p4,按照这个序列来,我们就可以实现所有进程都安全的执行并结束。

另一个例子,把这个数值调整一下,如下图,仍然选择p2:

当p2在运行中时,如下面状态,这时若p1发出请求,会响应吗?答案是不会。

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
银行家算法是一种用于避免死锁的算法,它最初是为了保证银行在发放现金贷款时不会发生不能满足所有客户需要的情况。这种算法可以通过动态地申请和释放资源来避免死锁的发生。 下面是一个简单的例子来说明银行家算法死锁避免过程: 假设我们有3个客户和3种资源类型。每个客户需要的资源如下: 客户1:需要2个资源1,1个资源2,3个资源3 客户2:需要1个资源1,2个资源2,1个资源3 客户3:需要2个资源1,1个资源2,2个资源3 同时,银行有以下资源可供分配: 资源1:有7个可用 资源2:有5个可用 资源3:有3个可用 在开始分配资源之前,银行家算法会检查分配资源后系统的状态是否安全。如果分配资源后系统处于安全状态,算法会进行分配;否则,资源请求将被推迟。 假设客户1请求1个资源1、1个资源2和2个资源3。这个请求可以被满足,因为系统的状态仍然是安全的。 然后,假设客户2请求1个资源1、1个资源2和1个资源3。这个请求同样可以被满足,因为系统的状态仍然是安全的。 最后,假设客户3请求1个资源1、1个资源2和1个资源3。这个请求也可以被满足,因为系统的状态仍然是安全的。 通过银行家算法,系统可以根据客户的资源请求动态地进行资源分配,以避免死锁的发生。这样,银行可以确保在发放贷款时不会发生不能满足所有客户需要的情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值