OS | 银行家算法C语言实现
算法简介
银行家算法(Banker’s Algorithm)是一个避免死锁( Deadlock)的著名算法,是由艾兹格·迪杰斯特拉在1965年为T.H.E系统设计的一种避免死锁产生的算法。它以银行借贷系统的分配策略为基础,判断并保证系统的安全运行。
算法目的
为了了解系统的资源分配情况,假定系统的任何一种资源在任意时刻只能被一个进程使用,任何进程已经占用的资源只能由进程自己释放,而不能由其他进程抢占,当进程申请的资源不能满足时,必须等待。因此只要资源分配算法能保证进程的资源请求,且不出现循环等待,则系统不会出现死锁。
算法原理
在避免死锁的方法中,所施加的限制条件较弱,有可能获得令人满意的系统性能。在该方法中把系统的状态分为安全状态和不安全状态,只要能使系统始终都处于安全状态,便可以避免发生死锁。
银行家算法的基本思想是分配资源之前,判断系统是否是安全的;若是,才分配。它是最具有代表性的避免死锁的算法。
设进程 cusneed 提出请求 \(REQUEST [i]\),则银行家算法按如下规则进行判断。
如果 \(REQUEST [cusneed] [i]<= NEED[cusneed][i]\),则转(2);否则,出错。
如果 \(REQUEST [cusneed] [i]<= AVAILABLE[i]\),则转(3);否则,等待。
系统试探分配资源,修改相关数据:
\(AVAILABLE[i]-=REQUEST[cusneed][i]\) ;
$ALLOCATION[cusneed][i]+=REQUEST[cusneed][i] $;
\(NEED[cusneed][i]-=REQUEST[cusneed][i]\);
系统执行安全性检查,如安全,则分配成立;否则试探险性分配作废,系统恢复原状,进程等待。
安全性检查算法
- (1)设置两个工作向量 \(Work=available;\ finish\)
- (2)从进程集合中找到一个满足下述条件的进程,
\(FINISH==false\) ;
\(NEED<=Work\) ;
如找到,执行(3);否则,执行(4)
- (3)设进程获得资源,可顺利执行,直至完成,从而释放资源。
Work=Work+ALLOCATION;
Finish=true;
GOTO 2
算法流程图

算法实现
代码学习自网络。
#include<stdio.h>
#define true 1
#define false 0
#define processNum 5
#define resourceNum 3
#define MAXINT 9999
typedef int bool;
int available[resourceNum] = {3, 3, 2};
int maxRequest[processNum][resourceNum] = {7, 5, 3, 3, 2, 2, 9, 0, 2, 2, 2, 2, 4, 3, 3};
int allocation[processNum][resourceNum] = {0, 1, 0, 2, 0, 0, 3, 0, 2, 2, 1, 1, 0, 0, 2};
int need[processNum][resourceNum] = {7, 4, 3, 1, 2, 2, 6, 0, 0, 0, 1, 1, 4, 3, 1};
bool Finish[processNum];
int safeSeries[processNum] = {MAXINT, MAXINT, MAXINT, MAXINT, MAXINT};
int request[resourceNum];
void Init() {
int i, j;
printf("输入进程数量、资源数量\n");
//scanf("%d %d",&processNum,&resourceNum);
printf("输入当前资源可用数目\n");
for (i = 0; i < resourceNum; i++) {
scanf("%d", &available[i]);
}
printf("输入最大需求矩阵\n");
for (i = 0; i < processNum; i++) {
for (j = 0; j < resourceNum; j++) {
scanf("%d", &maxRequest[i][j]);
}
}
printf("输入分配矩阵\n");
for (i = 0; i < processNum; i++) {
for (j = 0; j < resourceNum; j++) {
scanf("%d", &allocation[i][j]);
}
}
printf("输入当前需求矩阵\n");
for (i = 0; i < processNum; i++) {
for (j = 0; j < resourceNum; j++) {
scanf("%d", &need[i][j]);
}
}
}
void showInfo() {
int i, j;
printf("当前资源剩余:");
for (j = 0; j < resourceNum; j++) {
printf("%d ", available[j]);
}
printf("\n");
printf(" PID\t Max\t\tAllocation\tNeed\n");
for (i = 0; i < processNum; i++) {
printf(" P%d\t", i);
for (j = 0; j < resourceNum; j++) {
printf("%d ", maxRequest[i][j]);
}
printf("\t\t");
for (j = 0; j < resourceNum; j++) {
printf("%d ", allocation[i][j]);
}
printf("\t\t");
for (j = 0; j < resourceNum; j++) {
printf("%d ", need[i][j]);
}
printf("\n");
}
}
bool isSafe() {
int i, j, k;
int trueFinished = 0;
int work[resourceNum];
for (i = 0; i < resourceNum; i++) {
work[i] = available[i];
}
for (i = 0; i < processNum; i++) {
Finish[i] = false;
}
i = 0;
int temp = 0;
while (trueFinished != processNum) {
int j = 0;
if (Finish[i] != true) {
for (j = 0; j < resourceNum; j++) {
if (need[i][j] > work[j]) {break;}
}
}
if (j == resourceNum) {
Finish[i] = true;
SafeInfo(work, i);
for (k = 0; k < resourceNum; k++) {
work[k] += allocation[i][k];
}
int k2;
safeSeries[trueFinished++] = i;
}
i++;
if (i >= processNum) {
i = i % processNum;
if (temp == trueFinished)
break;
}
temp = trueFinished;
}
if (trueFinished == processNum) {
printf("\n系统安全!\n\n安全序列为:");
for (i = 0; i < processNum; i++) {
printf("%d ", safeSeries[i]);
}
return true;
}
printf("******系统不安全!******\n");
return false;
}
void SafeInfo(int *work, int i) {
int j;
printf(" P%d\t", i);
for (j = 0; j < resourceNum; j++) {
printf("%d ", work[j]);
}
printf("\t\t");
for (j = 0; j < resourceNum; j++) {
printf("%d ", need[i][j]);
}
printf("\t ");
for (j = 0; j < resourceNum; j++) {
printf("%d ", allocation[i][j]);
}
printf("\t\t");
for (j = 0; j < resourceNum; j++) {
printf("%d ", allocation[i][j] + work[j]);
}
printf("\n");
}
int main() {
int i, j, curProcess;
int wheInit = 0;
printf("是否使用内置数据?0是,1否:");
scanf("%d", &wheInit);
if (wheInit)
Init(); //可以不使用,选用内置的数据进行测试
printf("---------------------------------------------------------\n");
showInfo();
printf("\n系统安全情况分析\n");
printf(" PID\t Work\t\tNeed\tAllocation\tWork+Allocation\n");
isSafe();
while (true) {
printf("\n---------------------------------------------------------\n");
printf("\n输入要分配的进程:");
scanf("%d", &curProcess);
printf("\n输入要分配给进程P%d的资源:", curProcess);
for (j = 0; j < resourceNum; j++) {
scanf("%d", &request[j]);
}
for (j = 0; j < resourceNum; j++) {
if (request[j] <= need[curProcess][j])continue;
else {printf("ERROR!\n"); break;}
}
if (j == resourceNum) {
for (j = 0; j < resourceNum; j++) {
if (request[j] <= need[curProcess][j])continue;
else {printf("资源不足,等待中!\n"); break;}
}
if (j == resourceNum) {
for (j = 0; j < resourceNum; j++) {
available[j] -= request[j];
allocation[curProcess][j] += request[j];
need[curProcess][j] -= request[j];
}
printf("\n系统安全情况分析\n");
printf(" PID\t Work\t\tNeed\tAllocation\tWork+Allocation\n");
if (isSafe()) {
printf("分配成功!\n");
showInfo();
} else {
for (j = 0; j < resourceNum; j++) {
available[j] += request[j];
allocation[curProcess][j] -= request[j];
need[curProcess][j] += request[j];
}
printf("分配失败!\n");
showInfo();
}
}
}
}
}
实现效果


OS | 银行家算法C语言实现的更多相关文章
- 【操作系统】银行家算法实现(C语言)
[操作系统]银行家算法实现(C语言) 注意:本人编码水平很菜.算是自己的一个总结.可能会有我还没有发现的bug.如果有人发现后可以指出,不胜感激. 1.银行家算法: 我们可以把操作系统看作是银行家,操 ...
- [OS] 死锁相关知识点以及银行家算法详解
因此我们先来介绍一下死锁: 死锁特征 当出现死锁时,进程永远不能完成,并且系统资源被阻碍使用,阻止了其他作业开始执行.在讨论处理死锁问题的各种方法之前,先深入讨论一下死锁的特征. ·必要条件 (1)互 ...
- C语言实现 操作系统 银行家算法
/**************************************************** 银行家算法 算法思想: 1. 在多个进程中,挑选资源需求最小的进程Pmin. 可能存在多类资 ...
- C# Math.Round()的银行家算法
可能很多人都跟我一样,都只知道Math.Round()是C#中用来做四舍五入,保留指定小数位的 但实际上它并不是真正的四舍五入,而是银行家算法的四舍六入五取偶 事实上这也是IEEE的规范,因此所有符合 ...
- c/c++多线程模拟系统资源分配(并通过银行家算法避免死锁产生)
银行家算法数据结构 (1)可利用资源向量Available 是个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目.如果Available[j]=K,则表示系统中现有Rj类资源K个. (2) ...
- Round() 四舍五入 js银行家算法(转)
首先问一下round(0.825,2) 返回的结果,大家猜一猜, 首先SQL server 返回的是 0.83 js的返回结果 是0.83,code 如下: var b = 0.825; ...
- 银行家算法java实现
关于银行家算法的理论知识,课本或者百度上有好多资料,我就不再多说了,这里把我最近写的银行家算法的实现带码贴出来. 由于这是我们的一个实验,对系统资源数和进程数都指定了,所以这里也将其指定了,其中系统资 ...
- 操作系统,银行家算法模拟实现(Windows 环境 C++)
计算机操作系统课设需要,写了两个下午的银行家算法(陷在bug里出不来耽误了很多时间),参考计算机操作系统(汤子瀛) 实现过程中不涉及难度较大的算法,仅根据银行家算法的思想和步骤进行实现.以下为详细步骤 ...
- c++银行家算法
#include <iostream> #include<string> #define False 0 #define True 1 using namespace std; ...
- 银行家算法C++程序
此程序在Windows10 CodeBlocks17.12环境下测试运行,其他编程环境未经测试! 作业需求↓↓↓↓↓↓ 运行效果图如下 (codeblocks下载地址http://www.cod ...
随机推荐
- 【VMware NSX-T】在vCenter内直接将Manager设备删除后,ESXi上还遗留N-VDS交换机及网卡被占用等问题的解决方法。
由于之前在实验平台安装了NSX-T的测试环境,但是由于太忙了没怎么测试,后来实验环境出了点小问题,索性就将上面所有虚拟机给清空了.但是没想到上面遗留了NSX-T上创建的N-VDS交换机,还占用了服务器 ...
- 义无反顾马督工,Bert-vits2V210复刻马督工实践(Python3.10)
Bert-vits2更新了版本V210,修正了日/英的bert对齐问题,效果进一步优化:对底模使用的数据进行优化和加量,减少finetune失败以及电音的可能性:日语bert更换了模型,完善了多语言推 ...
- 2023-12-13:用go语言,密码是一串长度为n的小写字母,一则关于密码的线索纸条, 首先将字母a到z编号为0到25编号, 纸条上共有n个整数ai,其中a1表示密码里第一个字母的编号, 若i>1的
2023-12-13:用go语言,密码是一串长度为n的小写字母,一则关于密码的线索纸条, 首先将字母a到z编号为0到25编号, 纸条上共有n个整数ai,其中a1表示密码里第一个字母的编号, 若i> ...
- 解决yolo+cudnn+opencv+gpu的一些问题
问题描述: 在makefile文件中修改GPU=1 CUDNN=1 OPENCV=1,然后重新make,执行命令时出现: Yolov3 darknet: ./src/cuda.c:36: check_ ...
- 良心国产工具,比Xshell好用还免费!
使用或维护Linux系统的都知道,我们日常对服务器的操作,一般都会借助SSH工具远程登录到服务器之后进行操作.常用的SSH工具有不少,比如:Xshell.Putty.SSH Secure Shell ...
- 现代 CSS 解决方案:文字颜色自动适配背景色!
在 23 年的 CSS 新特性中,有一个非常重要的功能更新 -- 相对颜色. 简单而言,相对颜色的功能,让我们在 CSS 中,对颜色有了更为强大的掌控能力. 其核心功能就是,让我们能够基于一个现有颜色 ...
- MySQL 基础(四)锁
解决并发事务带来的问题 写-写情况 任意一种事务隔离级别都不允许 "脏写" 的发生,因为这样会使得数据混乱.所以,当多个未提交的事务相继对一条记录进行改动时,就需要使得这些事务串行 ...
- Odoo16—级联删除
我们在odoo中构建业务系统模块的时候,通常会使用one2many.many2one或many2many将模型进行关联,由此产生的数据也会通过外键发生关联.那么在odoo中删除数据的时候,如何关联删除 ...
- git blame 用法小记
1.概述 git管理的代码仓库,在协作开发中不可避免地会出现代码冲突,或者有新手错误地提交代码.出现问题不可怕,可怕的是找不到问题出在哪里.有时候找到出问题的代码,却不知道是谁提交的.git提供了一个 ...
- Altas&Ranger快速入门
Altas&Ranger快速入门 一.元数据 企业内部远行多种类型的数据库,有关系型数据库.非关系型数据库.图数据库.时序数据库等,常见有mysql.redis.Mongodb.oracle. ...