c++银行家算法总结.doc





《c++银行家算法总结.doc》由会员分享,可在线阅读,更多相关《c++银行家算法总结.doc(16页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精品文档 仅供参考 学习与交流c+银行家算法总结【精品文档】第 16 页算法的实现 一、初始化由用户输入数据,分别对可利用资源向量矩阵AVAILABLE、最大需求矩阵MAX、分配矩阵ALLOCATION、需求矩阵NEED赋值。二、银行家算法在避免死锁的方法中,所施加的限制条件较弱,有可能获得令人满意的系统性能。在该方法中把系统的状态分为安全状态和不安全状态,只要能使系统始终都处于安全状态,便可以避免发生死锁。银行家算法的基本思想是分配资源之前,判断系统是否是安全的;若是,才分配。它是最具有代表性的避免死锁的算法。设进程cusneed提出请求REQUEST i,则银行家算法按如下规则进行判断。(
2、1)如果REQUEST cusneed i= NEEDcusneedi,则转(2);否则,出错。(2)如果REQUEST cusneed i= AVAILABLEcusneedi,则转(3);否则,出错。(3)系统试探分配资源,修改相关数据: AVAILABLEi-=REQUESTcusneedi; ALLOCATIONcusneedi+=REQUESTcusneedi; NEEDcusneedi-=REQUESTcusneedi;(4)系统执行安全性检查,如安全,则分配成立;否则试探险性分配作废,系统恢复原状,进程等待。三、安全性检查算法运行安全性检查算法如下:1)Work = Availa
3、ble;Finish = false;2)寻找满足如下条件的i: Finishi=false并且NeediWorki; 如果不存在,则转步骤 4);3)Work = Work + Allocationi;Finishi = true; 转步骤 2);4)如果对于所有i,Finishi = true,则系统处于安全状态,否则处于不安全状态。 (1)设置两个工作向量Work=AVAILABLE;FINISH(2)从进程集合中找到一个满足下述条件的进程,FINISH=false;NEED=Work;如找到,执行(3);否则,执行(4)(3)设进程获得资源,可顺利执行,直至完成,从而释放资源。Work
4、+=ALLOCATION;Finish=true;GOTO 2(4)如所有的进程Finish= true,则表示安全;否则系统不安全。各算法流程图 #include using namespace std;#define MAXPROCESS50/*最大进程数*/ #define MAXRESOURCE100/*最大资源数*/ int AVAILABLEMAXRESOURCE; /*/ /* 可用资源数组 */ int MAXMAXPROCESSMAXRESOURCE; /*/ /* 最大需求矩阵 */ int ALLOCATIONMAXPROCESSMAXRESOURCE; /*/ /* 分
5、配矩阵 */ int NEEDMAXPROCESSMAXRESOURCE; /*/ /* 需求矩阵 */ int REQUESTMAXPROCESSMAXRESOURCE; /*/ /* 进程需要资源数 */ bool FINISHMAXPROCESS; /*/ /* 系统是否有足够的资源分配 */ int pMAXPROCESS; /*/ /* 记录序列 */ int m,n; /*/ /* m个进程,n个资源 */ void Init();bool Safe();void Bank();int main()Init();Safe();Bank();getchar(); / 给出系统拥有的每
6、种资源数,已经分配给每个进程的资源数,还有每个进程最多需要每种资源的个数,让你判断当前系统是不是安全的 void Init() /*/ /* 初始化算法 */ int i,j;cout m;cout n;cout 请输入每个进程最多所需的各资源数,按照 m x n 矩阵输入 endl; for (i = 0 ;i m;i + ) for (j = 0 ;j MAXij;cout 请输入每个进程已分配的各资源数,也按照 m x n 矩阵输入 endl; for (i = 0 ;i m;i + ) for (j = 0 ;j ALLOCATIONij;NEEDij = MAXij - ALLOCA
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- c+ 银行家 算法 总结

限制150内