银行家算法—简单易懂解题思路

来个题:
在这里插入图片描述

首先明确:Max—最大资源需求量
Need—需要资源量
Allocation—已分配资源量
Available—系统剩余资源数量

其中,Need=Max-Allocation
我们由此可以得出需求量Need的表格
在这里插入图片描述

比较Available中的每一个数(2 3 3)是否比Need中的大,很明显p1-5中只有p4和p5满足,
(这里说明一下安全序列不是唯一的,即答案不唯一)
如果满足,将Available与Allocation相加,例如:
此题中将p4中的已分配资源量与系统剩余资源量相加,得到4 3 7(原理是系统满足了p4的需求,p4将已分配资源归还)
而4 3 7又大于1 1 0,所以p5满足,Available变为7 4 11。由此类推,安全序列可为p4-p5-p1-
p2-p3
在这里插入图片描述

第二小问和第三小问的解题思路是一样的,第二题需要改变的前提是将初始Available的值2 3 3减去2 0 1,即0 3 2,p4的Allocation加上2 0 1,Need减去2 0 1,再观察剩余资源量能不能满足所有进程的需求,若能,则可实现资源分配,由此,此类问题便可迎刃而解了。

  • 6
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值