ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

操作系统 | 银行家算法举例

2021-12-30 14:03:23  阅读:280  来源: 互联网

标签:P2 Available 操作系统 Allocation 进程 算法 举例 Need 请求


举例说明:“若系统状态目前是安全的,若对某个申请评估时 在假定分配状态中,只要找到一个可满足线程就可断定系统是安全的”结论是错的。请构造一个例子进行证明。

例:在银行家算法中,若出现下述分配情况,试问:

若进程P2提出请求Request(1,2,2,2)后,系统能否将资源分配给它?

答:不能,按照银行家算法,首先检查Requesti [j] 是否小于等于 Need[i,j],在这里(1,2,2,2) < (2,3,5,6)满足条件,则再判断Requesti [j] 是否小于等于 Available[j],这里(1,2,2,2) <(1,6,2,2)满足!此时找到了一个可满足进程。

然后便试探性的将资源分配给P2,此时P2的Allocation项变为(2,5,7,6),Need项变为(1,1,3,4),Available项变为(0,4,0,0)必须执行安全性算法,第一步就发现找不到一个进程使得Need[i,j] <= Work[j];所以安全性检查失败,这个Request请求会造成死锁,系统将处于不安全状态,故本次试探分配作废,恢复原来的资源分配状态,让进程P2等待。故“只要找到一个可满足线程就可断定系统是安全的”是错误的。

笔记:

1.多个进程: { P0,P1,P2,P4 } 代表1,2,3,4四个需要临界资源的进程

2.几种资源:{ A, B ,C } 代表A,B,C三种临界资源

3.Claim:最大需求矩阵(进程完成执行需要的各资源总量)

Allocation:分配矩阵(某个进程现在已经拥有的各资源量)

Need:需求矩阵(某个进程仍需要的各资源量)

Available:可利用资源向量 (系统保有的供分配的资源量)

其中:Need = Max - Allocation ,仍然需要的量等于总需求量减去拥有的量

当进程请求一组资源时,假设同意该请求,从而改变了系统的状态,然后确定其结果是否还处于安全状态。如果是,同意这个请求;如果不是,阻塞该进程知道同意该请求后系统状态仍然是安全的。

标签:P2,Available,操作系统,Allocation,进程,算法,举例,Need,请求
来源: https://blog.csdn.net/weixin_47187147/article/details/122235308

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有