分类: C/C++
2014-09-12 19:10:38
1. 银行家算法中的数据结构
(1) 可利用资源向量Available。
这是一个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目,其初始值是系统中所配置的该类全部可用资源的数目,其数值随该类资源的分配和回收而动态地改变。如果Available[j]=K,则表示系统中现有Rj类资源K个。
(2) 最大需求矩阵Max。
这是一个n×m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。如果Max[i,j]=K,则表示进程i需要Rj类资源的最大数目为K。
(3) 分配矩阵Allocation。
这也是一个n×m的矩阵,它定义了系统中每一类资源当前已分配给每一进程的资源数。如果Allocation[i,j]=K,则表示进程i当前已分得Rj类资源的数目为K。?
(4) 需求矩阵Need。
这也是一个n×m的矩阵,用以表示每一个进程尚需的各类资源数。如果Need[i,j]=K,则表示进程i还需要Rj类资源K个,方能完成其任务。
Need[i,j]=Max[i,j] - Allocation[i,j]
2. 银行家算法
设Requesti是进程Pi的请求向量,如果Requesti[j]=K,表示进程Pi需要K个Rj类型的资源。当Pi发出资源请求后,系统按下述步骤进行检查:
(1) 如果Requesti[j]≤Need[i,j],便转向步骤2;否则认为出错,因为它所需要的资源数已超过它所宣布的最大值。
(2) 如果Requesti[j]≤Available[j],便转向步骤(3);否则,表示尚无足够资源,Pi须等待。
(3) 系统试探着把资源分配给进程Pi,并修改下面数据结构中的数值:
Available[j] := Available[j]-Requesti[j];
Allocation[i,j] := Allocation[i,j]+Requesti[j];
Need[i,j] := Need[i,j]-Requesti[j];
(4) 系统执行安全性算法,检查此次资源分配后,系统是否处于安全状态。若安全,才正式将资源分配给进程Pi,以完成本次分配;否则,将本次的试探分配作废,恢复原来的资源分配状态,让进程Pi等待。
3. 安全性算法
(1) 设置两个向量:
① 工作向量Work:它表示系统可提供给进程继续运行所需的各类资源数目,它含有m个元素,在执行安全算法开始时,Work := Available;
② Finish:它表示系统是否有足够的资源分配给进程,使之运行完成。开始时先做Finish[i] := false; 当有足够资源分配给进程时,再令Finish[i] := true。
(2) 从进程集合中找到一个能满足下述条件的进程:
① Finish[i]=false;
② Need[i,j]≤Work[j];
若找到,执行步骤(3),否则,执行步骤(4)。
(3) 当进程Pi获得资源后,可顺利执行,直至完成,并释放出分配给它的资源,故应执行:
Work[j] := Work[j]+Allocation[i,j];?
Finish[i] := true;?
go to step 2;
(4) 如果所有进程的Finish[i]=true都满足,则表示系统处于安全状态;否则,系统处于不安全状态。
总结:银行家算法分为两部分:
第一部分:是资源预分配算法,即对某进程的一个资源请求,先进行模拟分配,然后运行银行家算法的第二部分,找出是否存在安全序列。
第二部分:是安全性算法,找出当前系统状态是否有安全序列。
点击(此处)折叠或打开
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 1
请输入系统总共有的资源数:3
请输入总共有多少个进程:5
第1类资源有的资源实例:10
第2类资源有的资源实例:5
第3类资源有的资源实例:7
进程P[1]对第1类资源的最大需求量:7
进程P[1]对第2类资源的最大需求量:5
进程P[1]对第3类资源的最大需求量:3
进程P[2]对第1类资源的最大需求量:3
进程P[2]对第2类资源的最大需求量:2
进程P[2]对第3类资源的最大需求量:2
进程P[3]对第1类资源的最大需求量:9
进程P[3]对第2类资源的最大需求量:0
进程P[3]对第3类资源的最大需求量:2
进程P[4]对第1类资源的最大需求量:2
进程P[4]对第2类资源的最大需求量:2
进程P[4]对第3类资源的最大需求量:2
进程P[5]对第1类资源的最大需求量:4
进程P[5]对第2类资源的最大需求量:3
进程P[5]对第3类资源的最大需求量:3
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 0 0 7 5 3 7 5 3
P[2] 0 0 0 3 2 2 3 2 2
P[3] 0 0 0 9 0 2 9 0 2
P[4] 0 0 0 2 2 2 2 2 2
P[5] 0 0 0 4 3 3 4 3 3
系统剩余资源量: 10 5 7
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose
请输入申请资源的进程:1
请输入进程P[1]对1类资源的申请量:0
请输入进程P[1]对2类资源的申请量:1
请输入进程P[1]对3类资源的申请量:0
$$ 1 $$ 2 $$ 3 $$ 4 $$ 5
safe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 1 0 7 5 3 7 4 3
P[2] 0 0 0 3 2 2 3 2 2
P[3] 0 0 0 9 0 2 9 0 2
P[4] 0 0 0 2 2 2 2 2 2
P[5] 0 0 0 4 3 3 4 3 3
系统剩余资源量: 10 4 7
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:2
请输入进程P[2]对1类资源的申请量:2
请输入进程P[2]对2类资源的申请量:0
请输入进程P[2]对3类资源的申请量:0
$$ 1 $$ 2 $$ 3 $$ 4 $$ 5
safe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 1 0 7 5 3 7 4 3
P[2] 2 0 0 3 2 2 1 2 2
P[3] 0 0 0 9 0 2 9 0 2
P[4] 0 0 0 2 2 2 2 2 2
P[5] 0 0 0 4 3 3 4 3 3
系统剩余资源量: 8 4 7
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:3
请输入进程P[3]对1类资源的申请量:3
请输入进程P[3]对2类资源的申请量:0
请输入进程P[3]对3类资源的申请量:2
$$ 2 $$ 3 $$ 4 $$ 5 $$ 1
safe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 1 0 7 5 3 7 4 3
P[2] 2 0 0 3 2 2 1 2 2
P[3] 3 0 2 9 0 2 6 0 0
P[4] 0 0 0 2 2 2 2 2 2
P[5] 0 0 0 4 3 3 4 3 3
系统剩余资源量: 5 4 5
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:4
请输入进程P[4]对1类资源的申请量:2
请输入进程P[4]对2类资源的申请量:1
请输入进程P[4]对3类资源的申请量:1
$$ 2 $$ 4 $$ 5 $$ 1 $$ 3
safe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 1 0 7 5 3 7 4 3
P[2] 2 0 0 3 2 2 1 2 2
P[3] 3 0 2 9 0 2 6 0 0
P[4] 2 1 1 2 2 2 0 1 1
P[5] 0 0 0 4 3 3 4 3 3
系统剩余资源量: 3 3 4
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:5
请输入进程P[5]对1类资源的申请量:0
请输入进程P[5]对2类资源的申请量:0
请输入进程P[5]对3类资源的申请量:2
$$ 2 $$ 4 $$ 5 $$ 1 $$ 3
safe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 1 0 7 5 3 7 4 3
P[2] 2 0 0 3 2 2 1 2 2
P[3] 3 0 2 9 0 2 6 0 0
P[4] 2 1 1 2 2 2 0 1 1
P[5] 0 0 2 4 3 3 4 3 1
系统剩余资源量: 3 3 2
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:2
请输入进程P[2]对1类资源的申请量:1
请输入进程P[2]对2类资源的申请量:0
请输入进程P[2]对3类资源的申请量:2
$$ 2 $$ 4 $$ 5 $$ 1 $$ 3
safe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 1 0 7 5 3 7 4 3
P[2] 3 0 2 3 2 2 0 2 0
P[3] 3 0 2 9 0 2 6 0 0
P[4] 2 1 1 2 2 2 0 1 1
P[5] 0 0 2 4 3 3 4 3 1
系统剩余资源量: 2 3 0
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:5
请输入进程P[5]对1类资源的申请量:3
P[5]必须等待
请输入进程P[5]对2类资源的申请量:3
请输入进程P[5]对3类资源的申请量:0
unsafe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:1
请输入进程P[1]对1类资源的申请量:0
请输入进程P[1]对2类资源的申请量:2
请输入进程P[1]对3类资源的申请量:0
unsafe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 1 0 7 5 3 7 4 3
P[2] 3 0 2 3 2 2 0 2 0
P[3] 3 0 2 9 0 2 6 0 0
P[4] 2 1 1 2 2 2 0 1 1
P[5] 0 0 2 4 3 3 4 3 1
系统剩余资源量: 2 3 0
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 2
请输入申请资源的进程:1
请输入进程P[1]对1类资源的申请量:0
请输入进程P[1]对2类资源的申请量:1
请输入进程P[1]对3类资源的申请量:0
$$ 2 $$ 4 $$ 5 $$ 1 $$ 3
safe static
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 3
当前的系统状态
目前占有量 最大需求量 尚需要量
进程 1类 2类 3类 1类 2类 3类 1类 2类 3类
P[1] 0 2 0 7 5 3 7 3 3
P[2] 3 0 2 3 2 2 0 2 0
P[3] 3 0 2 9 0 2 6 0 0
P[4] 2 1 1 2 2 2 0 1 1
P[5] 0 0 2 4 3 3 4 3 1
系统剩余资源量: 2 2 0
★ 欢迎使用本程序 ★
1:输入系统的资源数、申请进程数、每个类资源的实例数
2:…………………………………… 输入进程的资源申请
3:…………………………………………… 输出系统状态
4:………………………………………………… 退出程序
please choose 4
谢谢使用
See you next time!!!
[root@liixun 2011级计科1班作业---11---银行家算法---C语言实现---030---毕赖子]#