银行家算法

本文介绍了一个基于银行家算法的资源分配模拟程序。该程序通过定义最大需求矩阵、已分配资源矩阵和需求矩阵来模拟资源分配过程,并实现了资源请求、释放等功能。通过检查系统是否处于安全状态,确保了资源分配的安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

*banker.h*

///#include < stdio.h >

//系统中进程的数量
//#define PRO_NUM 5

typedef struct{
int A;
int B;
int C;
int D;
}RESOURCE;

//最大需求矩阵
RESOURCE max_need[PRO_NUM] =
{
{0,1,4,4},
{2,6,4,1},
{3,5,9,9},
{0,7,6,5},
{1,5,5,9}
};

//已分配资源矩阵
RESOURCE allocation[PRO_NUM] =
{
{0,1,3,1},
{1,0,1,1},
{1,2,4,3},
{0,2,3,2},
{1,0,2,3}
};

//需求矩阵
RESOURCE need[PRO_NUM] =
{
{0,0,1,3},
{1,6,3,0},
{2,3,5,6},
{0,5,3,3},
{0,5,3,6}
};

RESOURCE available = {2,7,3,3};

*banker.c*

// #include “banker.h”

int check_safe()
{
RESOURCE temp = available;
int checked[PRO_NUM] = {0,0,0,0,0};//0为检查未完成,1为检查完成
int i = 0;

while(i != PRO_NUM)
{
    if(checked[i] == 0)
    {
        if((need[i].A <= temp.A) && (need[i].B <= temp.B) && (need[i].C <= temp.C) && (need[i].D <= temp.D))
        {
            temp.A += allocation[i].A;
            temp.B += allocation[i].B;
            temp.C += allocation[i].C;
            temp.D += allocation[i].D;
            checked[i] = 1;
            printf("process %d is checked\n",i + 1);
            i = -1;
        }
    }
    i++;
}

for(i = 0; i < PRO_NUM; i++)
{
    if(checked[i] == 0)
    {
        return 0;
    }
}
return 1;

}

void print_all()
{
int i;

printf("**************资源分配情况**************\n");
printf("进程     最大需求     已分配     还需要 \n");
printf("        A  B  C  D  A  B  C  D  A  B  C  D \n");

for(i = 0; i < PRO_NUM; i++)
{
    printf("P%d      %d  %d  %d  %d  %d  %d  %d  %d  %d  %d  %d  %d\n",i,max_need[i].A,max_need[i].B,max_need[i].C,max_need[i].D,allocation[i].A,allocation[i].B,allocation[i].C,allocation[i].D,need[i].A,need[i].B,need[i].C,need[i].D);
}

printf("目前系统可用资源: A:%d B:%d C:%d D:%d\n",available.A,available.B,available.C,available.D);
printf("****************************************\n");

}

void allocate(int n_pro,RESOURCE *n_res)
{
need[n_pro].A = need[n_pro].A - n_res->A;
need[n_pro].B = need[n_pro].B - n_res->B;
need[n_pro].C = need[n_pro].C - n_res->C;
need[n_pro].D = need[n_pro].D - n_res->D;

available.A = available.A - n_res->A;
available.B = available.B - n_res->B;
available.C = available.C - n_res->C;
available.D = available.D - n_res->D;

allocation[n_pro].A = allocation[n_pro].A + n_res->A;
allocation[n_pro].B = allocation[n_pro].B + n_res->B;
allocation[n_pro].C = allocation[n_pro].C + n_res->C;
allocation[n_pro].D = allocation[n_pro].D + n_res->D;
//printf("目前系统可用资源: A:%d B:%d C:%d \n",available.A,available.B,available.C);
//sleep(1);

}

void ret(int n_pro,RESOURCE *n_res)
{
need[n_pro].A = need[n_pro].A + n_res->A;
need[n_pro].B = need[n_pro].B + n_res->B;
need[n_pro].C = need[n_pro].C + n_res->C;
need[n_pro].D = need[n_pro].D + n_res->D;

available.A = available.A + n_res->A;
available.B = available.B + n_res->B;
available.C = available.C + n_res->C;
available.D = available.D + n_res->D;

allocation[n_pro].A = allocation[n_pro].A - n_res->A;
allocation[n_pro].B = allocation[n_pro].B - n_res->B;
allocation[n_pro].C = allocation[n_pro].C - n_res->C;
allocation[n_pro].D = allocation[n_pro].D - n_res->D;

}

int request(int n_pro,RESOURCE *n_res)
{
if((n_res->A <= need[n_pro].A) && (n_res->B <= need[n_pro].B) && (n_res->C <= need[n_pro].C) && (n_res->D <= need[n_pro].D))
{
if((n_res->A <= available.A) && (n_res->B <= available.B) && (n_res->C <= available.C) && (n_res->D <= available.D))
{
allocate(n_pro,n_res);

        if(check_safe())
        {
            if((need[n_pro].A == 0) && (need[n_pro].B == 0) && (need[n_pro].C == 0) && (need[n_pro].D == 0))
            {
                available.A = available.A + max_need[n_pro].A;
                available.B = available.B + max_need[n_pro].B;
                available.C = available.C + max_need[n_pro].C;
                available.D = available.D + max_need[n_pro].D;
            }
            return 1;
        }
        else
        {
            printf("当前系统状态不安全!\n");
            printf("正在返回安全状态...\n");
            ret(n_pro,n_res);
            printf("返回安全状态成功!\n");
            return 0;
        }
    }
    else
    {
        printf("出错啦:请求资源大于系统可使用资源!\n");
        return 0;
    }
}
else
{
    printf("出错啦:请求资源大于需求资源!\n");
    return 0;
}

}
/*
void safe_1(int finished)
{
int i;
int j;

static int a = 0;
static num = 0;
static seq[PRO_NUM];

if(finished == PRO_NUM)
{
    num++;
    for(i = 0; i < PRO_NUM; i++)
    {
        printf("%d ",seq[i]);
    }
    printf("\n");
    return;
}
for(i = 0; i < PRO_NUM; i++)
{
    if(finished)
}

}*/

void safe()
{
int tmp = PRO_NUM;
int n = 1;

while(tmp != 0)
{
    n = n * tmp;
    tmp--;
}

int max[n][PRO_NUM];

int a,b,c,d,e;

int m = 0;
int count = 0;
RESOURCE temp = available;

for(a = 0; a < 5; a++)
{
    for(b = 0; b < 5; b++)
    {
        for(c = 0; c < 5; c++)
        {
            for(d = 0; d < 5; d++)
            {
                for(e = 0; e < 5; e++)
                {
                    if((a != b) && (a != c) && (a != d) && (a !=e) && (b != c) && (b != d) && (b != e) && (c != d) && (c != e) && (d != e))
                    {
                        max[m][0] = a;
                        max[m][1] = b;
                        max[m][2] = c;
                        max[m][3] = d;
                        max[m][4] = e;
                        m++;
                    }
                }
            }
        }
    }
}

for(a = 0; a < m; a++)
{
    temp = available;
    for(b = 0; b < 5; b++)
    {
    if((need[max[a][b]].A <= temp.A) && (need[max[a][b]].B <= temp.B) && (need[max[a][b]].C <= temp.C) && (need[max[a][b]].D <= temp.D))
        {
            temp.A += allocation[max[a][b]].A;
            temp.B += allocation[max[a][b]].B;
            temp.C += allocation[max[a][b]].C;
            temp.D += allocation[max[a][b]].D;
        }
        else
        {
            break;
        }
    }
    if(b == 5)
    {
          count++;
          printf("第%d种安全序列为:",count);
          for(c = 0; c < 5; c++)
          {
              if((need[max[a][c]].A != 0) || (need[max[a][c]].B != 0) || (need[max[a][c]].C != 0) && (need[max[a][c]].D != 0))
              {      
                  printf("%d ",max[a][c]);             
              }
          }
          printf("\n");
    }
}

}

int main()
{
int i;
int n_pro;
char choose = ‘y’;
char choose_1;
RESOURCE n_res;

system("clear");
printf("************************************\n");
printf("***********银行家算法演示***********\n");
printf("************************************\n");
printf("首先检查初始状态是否安全...\n");

if(check_safe() == 1)
{
    printf("系统处于安全状态!^-^\n");
}
else
{
    printf("系统处于不安全状态!T-T\n演示结束!\n");
    return -1;
}

sleep(2);
printf("你想要输出所有的安全序列吗?(y/n):\n");
getchar();
scanf("%c",choose_1);
if(choose == 'y')
{
    safe();
}
sleep(2);

while(choose != 'n')
{
    system("clear");
    print_all();

    printf("请输入请求分配的进程和对ABC三类资源的请求:\n");
    scanf("%d %d %d %d %d",&n_pro,&n_res.A,&n_res.B,&n_res.C,&n_res.D);

    if(request(n_pro,&n_res))
    {
        printf("分配成功!^-^\n");
        safe();
    }
    else
    {
        printf("分配失败!T-T!\n");
    }
    for(i = 0; i < PRO_NUM; i++)
    {
        if((need[i].A != 0) || (need[i].B != 0) || (need[i].C != 0) || (need[i].D != 0))
        {
            break;
        }
    }
    if(i == 5)
    {
        break;
    }
   // safe();
    printf("是否继续分配?(任意键继续,n退出):\n");
    getchar();
    scanf("%c",&choose);
}

system("clear");
print_all();
printf("***********银行家算法演示完成***********\n");
printf("****************************************\n");

return 0;

}

操作系统课的实验(银行家算法)#include "malloc.h"   #include "stdio.h"   #include "stdlib.h"   #define alloclen sizeof(struct allocation)   #define maxlen sizeof(struct max)   #define avalen sizeof(struct available)   #define needlen sizeof(struct need)   #define finilen sizeof(struct finish)   #define pathlen sizeof(struct path)   struct allocation   {   int value;   struct allocation *next;   };   struct max   {   int value;   struct max *next;   };   struct available /*可用资源数*/   {   int value;   struct available *next;   };   struct need /*需求资源数*/   {   int value;   struct need *next;   };   struct path   {   int value;   struct path *next;   };   struct finish   {   int stat;   struct finish *next;   };   int main()   {   int row,colum,status=0,i,j,t,temp,processtest;   struct allocation *allochead,*alloc1,*alloc2,*alloctemp;   struct max *maxhead,*maxium1,*maxium2,*maxtemp;   struct available *avahead,*available1,*available2,*workhead,*work1,*work2,*worktemp,*worktemp1;   struct need *needhead,*need1,*need2,*needtemp;   struct finish *finihead,*finish1,*finish2,*finishtemp;   struct path *pathhead,*path1,*path2;   printf("\n请输入系统资源的种类数:");   scanf("%d",&colum);   printf("请输入现时内存中的进程数:");   scanf("%d",&row);   printf("请输入已分配资源矩阵:\n");   for(i=0;i<row;i++)   {   for (j=0;jnext=alloc2->next=NULL;   scanf("%d",&allochead->value);   status++;   }   else   {   alloc2=(struct allocation *)malloc(alloclen);   scanf("%d,%d",&alloc2->value);   if(status==1)   {   allochead->next=alloc2;   status++;   }   alloc1->next=alloc2;   alloc1=alloc2;   }   }   }   alloc2->next=NULL;   status=0;   printf("请输入最大需求矩阵:\n");   for(i=0;i<row;i++)   {   for (j=0;jnext=maxium2->next=NULL;   scanf("%d",&maxium1->value);   status++;   }   else   {   maxium2=(struct max *)malloc(maxlen);   scanf("%d,%d",&maxium2->value);   if(status==1)   {   maxhead->next=maxium2;   status++;   }   maxium1->next=maxium2;   maxium1=maxium2;   }   }   }   maxium2->next=NULL;   status=0;   printf("请输入现时系统剩余的资源矩阵:\n");   for (j=0;jnext=available2->next=NULL;   work1->next=work2->next=NULL;   scanf("%d",&available1->value);   work1->value=available1->value;   status++;   }   else   {   available2=(struct available*)malloc(avalen);   work2=(struct available*)malloc(avalen);   scanf("%d,%d",&available2->value);   work2->value=available2->value;   if(status==1)   {   avahead->next=available2;   workhead->next=work2;   status++;   }   available1->next=available2;   available1=available2;   work1->next=work2;   work1=work2;   }   }   available2->next=NULL;   work2->next=NULL;   status=0;   alloctemp=allochead;   maxtemp=maxhead;   for(i=0;i<row;i++)   for (j=0;jnext=need2->next=NULL;   need1->value=maxtemp->value-alloctemp->value;   status++;   }   else   {   need2=(struct need *)malloc(needlen);   need2->value=(maxtemp->value)-(alloctemp->value);   if(status==1)   {   needhead->next=need2;   status++;   }   need1->next=need2;   need1=need2;   }   maxtemp=maxtemp->next;   alloctemp=alloctemp->next;   }   need2->next=NULL;   status=0;   for(i=0;inext=finish2->next=NULL;   finish1->stat=0;   status++;   }   else   {   finish2=(struct finish*)malloc(finilen);   finish2->stat=0;   if(status==1)   {   finihead->next=finish2;   status++;   }   finish1->next=finish2;   finish1=finish2;   }   }   finish2->next=NULL; /*Initialization compleated*/   status=0;   processtest=0;   for(temp=0;temp<row;temp++)   {   alloctemp=allochead;   needtemp=needhead;   finishtemp=finihead;   worktemp=workhead;   for(i=0;istat==0)   {   for(j=0;jnext,worktemp=worktemp->next)   if(needtemp->valuevalue)   processtest++;   if(processtest==colum)   {   for(j=0;jvalue+=alloctemp->value;   worktemp1=worktemp1->next;   alloctemp=alloctemp->next;   }   if(status==0)   {   pathhead=path1=path2=(struct path*)malloc(pathlen);   path1->next=path2->next=NULL;   path1->value=i;   status++;   }   else   {   path2=(struct path*)malloc(pathlen);   path2->value=i;   if(status==1)   {   pathhead->next=path2;   status++;   }   path1->next=path2;   path1=path2;   }   finishtemp->stat=1;   }   else   {   for(t=0;tnext;   finishtemp->stat=0;   }   }   else   for(t=0;tnext;   alloctemp=alloctemp->next;   }   processtest=0;   worktemp=workhead;   finishtemp=finishtemp->next;   }   }   path2->next=NULL;   finishtemp=finihead;   for(temp=0;tempstat==0)   {   printf("\n系统处于非安全状态!\n");   exit(0);   }   finishtemp=finishtemp->next;   }   printf("\n系统处于安全状态.\n");   printf("\n安全序列为: \n");   do   {   printf("p%d ",pathhead->value);   }   while(pathhead=pathhead->next);   printf("\n");   return 0;   } #include "string.h" #include #include #define M 5 #define N 3 #define FALSE 0 #define TRUE 1 /*M个进程对N类资源最大资源需求量*/ int MAX[M][N]={{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}}; /*系统可用资源数*/ int AVAILABLE[N]={10,5,7}; /*M个进程对N类资源最大资源需求量*/ int ALLOCATION[M][N]={{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0}}; /*M个进程已经得到N类资源的资源量 */ int NEED[M][N]={{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}}; /*M个进程还需要N类资源的资源量*/ int Request[N]={0,0,0}; void main() { int i=0,j=0; char flag='Y'; void showdata(); void changdata(int); void rstordata(int); int chkerr(int); showdata(); while(flag=='Y'||flag=='y') { i=-1; while(i=M) { printf("请输入需申请资源的进程号(从0到"); printf("%d",M-1); printf(",否则重输入!):"); scanf("%d",&i); if(i=M)printf("输入的进程号不存在,重新输入!\n"); } printf("请输入进程"); printf("%d",i); printf("申请的资源数\n"); for (j=0;jNEED[i][j]) { printf("进程"); printf("%d",i); printf("申请的资源数大于进程"); printf("%d",i); printf("还需要"); printf("%d",j); printf("类资源的资源量!申请不合理,出错!请重新选择!\n"); /*printf("申请不合理,出错!请重新选择!\n");*/ flag='N'; break; } else { if(Request[j]>AVAILABLE[j]) { printf("进程"); printf("%d",i); printf("申请的资源数大于系统可用"); printf("%d",j); printf("类资源的资源量!申请不合理,出错!请重新选择!\n"); /*printf("申请不合理,出错!请重新选择!\n");*/ flag='N'; break; } } } if(flag=='Y'||flag=='y') { changdata(i); if(chkerr(i)) { rstordata(i); showdata(); } else showdata(); } else showdata(); printf("\n"); printf("是否继续银行家算法演示,按'Y'或'y'键继续,按'N'或'n'键退出演示: "); scanf("%c",&flag); } } void showdata() { int i,j; printf("系统可用的资源数为:\n"); printf(" "); for (j=0;j<N;j++){ printf(" 资源"); printf("%d",j); printf(":"); printf("%d",AVAILABLE[j]); /*printf("\n");*/ /* cout<<endl; // cout<<"各进程资源的最大需求量:"<<endl<<endl; // for (i=0;i<M;i++) // { // cout<<"进程"<<i<<":"; // for (j=0;j<N;j++)cout<<" 资源"<<j<<": "<<MAX[i][j]; // cout<<endl; */ } printf("\n"); printf("各进程还需要的资源量:\n"); for (i=0;i<M;i++) { printf(" 进程"); printf("%d",i); printf(":"); for (j=0;j<N;j++){ printf("资源"); printf("%d",j); printf(":"); printf("%d",NEED[i][j]); /*printf("\n");*/ } printf("\n"); } printf("各进程已经得到的资源量: \n"); for (i=0;i<M;i++) { printf(" 进程"); printf("%d",i); /*printf(":\n");*/ for (j=0;j<N;j++){ printf("资源"); printf("%d",j); printf(":"); printf("%d",ALLOCATION[i][j]); /*printf("\n");*/ } printf("\n"); } } void changdata(int k) { int j; for (j=0;j<N;j++) { AVAILABLE[j]=AVAILABLE[j]-Request[j]; ALLOCATION[k][j]=ALLOCATION[k][j]+Request[j]; NEED[k][j]=NEED[k][j]-Request[j]; } }; void rstordata(int k) { int j; for (j=0;j<N;j++) { AVAILABLE[j]=AVAILABLE[j]+Request[j]; ALLOCATION[k][j]=ALLOCATION[k][j]-Request[j]; NEED[k][j]=NEED[k][j]+Request[j]; } }; int chkerr(int s) { int WORK,FINISH[M],temp[M]; int i,j,k=0; for(i=0;i<M;i++)FINISH[i]=FALSE; for(j=0;j<N;j++) { WORK=AVAILABLE[j]; i=s; while(i<M) { if (FINISH[i]==FALSE&&NEED[i][j]<=WORK) { WORK=WORK+ALLOCATION[i][j]; FINISH[i]=TRUE; temp[k]=i; k++; i=0; } else { i++; } } for(i=0;i<M;i++) if(FINISH[i]==FALSE) { printf("\n"); printf("系统不安全!!! 本次资源申请不成功!!!\n"); printf("\n"); return 1; } } printf("\n"); printf("经安全性检查,系统安全,本次分配成功。\n"); printf("\n"); printf(" 本次安全序列:"); for(i=0;i"); } printf("\n"); return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值