银行家算法C语言实现(纯记录

#include<stdio.h>
#include<time.h>
#include<unistd.h>
#include<stdlib.h>
#include<string.h>

#define True 1
#define False 0

const int left = 0;
const int right = 9; 

enum State
{
  Error,
  Block,
  Success
};

int generating_data(int left,int right)
{
  static int seed = 1;
  srand((unsigned)time(NULL) + seed * seed + seed);
  int random_data;
  random_data = rand() % (right - left + 1) + left;
  ++seed;
  return random_data;
}

void free_resouce(int** resource,int size)
{
  for(int i = 0;i < size;++i)
    free((void*)resource[i]);
  free((void*)resource);
}

void print(int* p,int size)
{
  for(int i = 0;i < size;++i)
  {
    printf("%d ",p[i]);
  }
  printf("\n");
}

void print_current_state(int processes,int resource_types,int* available,int* security_queue,
                         int** max,int** allocation,int** need,int** work_plus_allocation)
{
  printf("Available:");
  print(available,resource_types);
  enum MatrixType
  {
    Max = 0,
    Allocation,
    Need,
    Work_Plus_Allocation
  };
  printf("\t\t%-20s%-20s%-20s%s\n","Max","Allocation","Need","Work+Allocation");
  int** matrix_ptr = NULL;
  for(int i = 0;i < processes;++i)
  {
    printf("Process%d\t",security_queue[i]);
    for(enum MatrixType matrix_type = Max;matrix_type <= Work_Plus_Allocation;++matrix_type)
    {
      switch(matrix_type)
      {
        case Max:matrix_ptr = max;
          break;
        case Allocation:matrix_ptr = allocation;
          break;
        case Need:matrix_ptr = need;
          break;
        case Work_Plus_Allocation:matrix_ptr = work_plus_allocation;
          break;
        default:break;
      }
      for(int j = 0;j < resource_types;++j)
      {
        if(matrix_ptr[security_queue[i]][j] == -1)
        {
          printf("%s ","None");
          continue;
        }
        printf("%d ",matrix_ptr[security_queue[i]][j]);
      }
      int placeholder_num = 20 - (resource_types * 2);
      for(int k = 0;k < placeholder_num;++k)
        printf(" ");
    }
    printf("\n");
  }
  matrix_ptr = NULL;
}

int detect_1(int* request,int** need,int process_no,int resource_types)
{
  int is_legal = True;
  for(int i = 0;i < resource_types;++i)
  {
    if(request[i] > need[process_no][i])
    {
      is_legal = False;
      break;
    }
  }
  return is_legal;
}

int detect_2(int* request,int* available,int process_no,int resource_types)
{
  int is_legal = True;
  for(int i = 0;i < resource_types;++i)
  {
    if(request[i] > available[i])
    {
      is_legal = False;
      break;
    }
  }
  return is_legal;
}

typedef struct DataLog
{
  int* available_last;
  int* allocation_last;
  int* need_last;
}DataLog;

void record(int* p,int* p_log,int resource_types)
{
  for(int i = 0;i < resource_types;++i)
  {
    p_log[i] = p[i];
  }
}

int security_testing(int resource_types,int processes,
                     int* available,int** max,int** need,int** allocation)
{
  int* work = (int*)malloc(sizeof(int) * resource_types);
  memcpy(work,available,sizeof(int) * resource_types);
  int* security_queue = (int*)malloc(sizeof(int) * processes);
  for(int i = 0;i < processes;++i)
  {
    security_queue[i] = -1;
  }
  int* finish = (int*)malloc(sizeof(int) * processes);
  for(int i = 0;i < processes;++i)
  {
    finish[i] = False;
  }
  int** work_plus_allocation = (int**)malloc(sizeof(int*) * processes); 
  for(int i = 0;i < processes;++i)
  {
    work_plus_allocation[i] = (int*)malloc(sizeof(int) * resource_types);
  }
  int is_continue = True;
  int count = 0;
  while(is_continue)
  {
    is_continue = False;
    for(int i = 0;i < processes;++i)
    {
      if(finish[i] == True) continue;
      int legal = True;     
      for(int j = 0;j < resource_types;++j)
      {
        if(need[i][j] > work[j])
        {
          legal = False;break;
        }
      }
      if(legal)
      {
        finish[i] = True;
        security_queue[count] = i;
      #ifdef _DEBUG_
        printf("Security queue[%d]=%d\n",count,i);
      #endif
        for(int j = 0;j < resource_types;++j)
        {
          work[j] = work[j] + allocation[i][j];
          work_plus_allocation[i][j] = work[j];
        }
        is_continue = True;
        ++count;
        break;
      }
    }
  }
  int is_security = True;
  for(int i = 0;i < processes;++i)
  {
    if(finish[i] == False)
    {
      is_security = False;
      break;
    }
  }
  if(is_security)
  {
    print_current_state(processes,resource_types,available,security_queue,max,allocation,need,work_plus_allocation);
  }
  free((void*)finish);
  free((void*)security_queue);
  free((void*)work);
  free_resouce(work_plus_allocation,processes);
  return is_security;
}

DataLog* try_to_allocate(int* request,int* available,
                         int** allocation,int** need,
                         int process_no,int resource_types)
{
  DataLog* data_log = (DataLog*)malloc(sizeof(DataLog));
  data_log->available_last = (int*)malloc(sizeof(int) * resource_types);
  record(available,data_log->available_last,resource_types);
  for(int i = 0;i < resource_types;++i)
  {
    available[i] = available[i] - request[i];
  }
  data_log->allocation_last = (int*)malloc(sizeof(int) * resource_types);
  record(allocation[process_no],data_log->allocation_last,resource_types);
  for(int i = 0;i < resource_types;++i)
  {
    allocation[process_no][i] = allocation[process_no][i] + request[i];
  }
  data_log->need_last = (int*)malloc(sizeof(int) * resource_types);
  record(need[process_no],data_log->need_last,resource_types);
  for(int i = 0;i < resource_types;++i)
  {
    need[process_no][i] = need[process_no][i] - request[i];
  }
#ifdef _DEBUG_
  printf("Available last\n");
  print(data_log->available_last,resource_types);
  printf("Allocation last\n");
  print(data_log->allocation_last,resource_types);
  printf("Need last\n");
  print(data_log->need_last,resource_types);
#endif
  return data_log;
}

enum State request_resources(int processes,int resource_types,
                             int* available,int** max,int** allocation,int** need)
{
  enum State state;
  int process_no;
#ifdef _DEBUG_
  printf("Input request process number:");
  scanf("%d",&process_no);
#else
  process_no = generating_data(0,processes - 1);
#endif
  printf("Process no:%d\n",process_no);
  int* request = (int*)malloc(sizeof(int) * resource_types);
#ifdef _DEBUG_
  printf("Input request vector:");
  for(int i = 0;i < resource_types;++i)
  {
    scanf("%d",&request[i]);
  }
#else
  for(int i = 0;i < resource_types;++i)
  {
    request[i] = generating_data(left,right);
  }
#endif
  printf("Request:");
  print(request,resource_types);
  printf("\n");
  int is_legal;
  is_legal = detect_1(request,need,process_no,resource_types);
  if(is_legal == False)
  {
    state = Error;
    return state;
  }
  is_legal = detect_2(request,available,process_no,resource_types);
  if(is_legal == False)
  {
    state = Block;
    return state;
  }
  DataLog* data_log = try_to_allocate(request,available,allocation,need,process_no,resource_types);
  int is_security = security_testing(resource_types,processes,available,max,need,allocation);
  if(is_security == False)
  {
    state = Block;
    for(int i = 0;i < resource_types;++i)
    {
      available[i] = data_log->available_last[i];
      allocation[process_no][i] = data_log->allocation_last[i];
      need[process_no][i] = data_log->allocation_last[i];
    }
  }
  else
  {
    state = Success;
  }
  free((void*)data_log->available_last);
  free((void*)data_log->allocation_last);
  free((void*)data_log->need_last);
  free((void*)data_log);
  free((void*)request);
  return state;
}

int main(int argc,char** argv) {
  int processes;
  /* Generating random data */
  // The number of processe
#ifdef _DEBUG_
  printf("Input the number of processes:");
  scanf("%d",&processes);
#else
  processes = generating_data(left + 1,right - 3);
#endif
  printf("The number of processes:%d\n",processes);
  // The number of resource types
  int resource_types;
#ifdef _DEBUG_
  printf("Input the number of of resource types:");
  scanf("%d",&resource_types);
#else
  resource_types = generating_data(left + 1,right - 3);
#endif
  printf("The number of resource types:%d\n",resource_types);
  // The number of different types of resources
  int* resource_total = (int*)malloc(sizeof(int) * resource_types);
#ifdef _DEBUG_
  printf("Input the number of different types of resources:");
  for(int i = 0;i < resource_types;++i)
  {
    scanf("%d",&resource_total[i]);
  }
#else
  for(int i = 0;i < resource_types;++i)
  {
    resource_total[i] = generating_data(left + 5,right + 5);
  }
#endif
  printf("The number of different types of resources:");
  print(resource_total,resource_types);
  int* resource_total_copy = (int*)malloc(sizeof(int) * resource_types);
  memcpy(resource_total_copy,resource_total,sizeof(int) * resource_types);
  // Max
  int** max = (int**)malloc(sizeof(int*) * processes);
#ifdef _DEBUG_
  printf("Input Max:\n");
  for(int i = 0;i < processes;++i)
  {
    max[i] = (int*)malloc(sizeof(int) * resource_types);
    for(int j = 0;j < resource_types;++j)
    {
      scanf("%d",&max[i][j]);
    }
  }
#else
  for(int i = 0;i < processes;++i)
  {
    max[i] = (int*)malloc(sizeof(int) * resource_types);
    for(int j = 0;j < resource_types;++j)
    {
      // Maximum quantity required
      max[i][j] = generating_data(left,right);
    }
  }
#endif
  // Allocation
  int** allocation = (int**)malloc(sizeof(int*) * processes);
#ifdef _DEBUG_
  printf("Input Allocation:\n");
  for(int i = 0;i < processes;++i)
  {
    allocation[i] = (int*)malloc(sizeof(int) * resource_types);
    for(int j = 0;j < resource_types;++j)
    {
      scanf("%d",&allocation[i][j]);
    }
  }
#else
  for(int i = 0;i < processes;++i)
  {
    allocation[i] = (int*)malloc(sizeof(int) * resource_types);
    for(int j = 0;j < resource_types;++j)
    {
      // Number of allocated resources
      int right_range = (max[i][j] < resource_total[j] ? max[i][j] : resource_total[j]);
      allocation[i][j] = generating_data(left,right_range);
      resource_total[j] = resource_total[j] - allocation[i][j];
    }
  }
#endif
  // Need
  int** need = (int**)malloc(sizeof(int*) * processes);
  for(int i = 0;i < processes;++i)
  {
    need[i] = (int*)malloc(sizeof(int) * resource_types);
    for(int j = 0;j < resource_types;++j)
    {
      // Number of resources still needed
      need[i][j] = max[i][j] - allocation[i][j];
    }
  }
  // Available
  int* available = (int*)malloc(sizeof(int) * resource_types);
  for(int i = 0;i < resource_types;++i)
  {
    // The number of resouces
    int have_allocated = 0;
    for(int j = 0;j < processes;++j)
    {
      have_allocated += allocation[j][i];
    }
    available[i] = resource_total_copy[i] - have_allocated;
  }

  /* Manual data entry */

  /* To peek initial state */
  int** work_plus_allocation = (int**)malloc(sizeof(int*) * processes);
  for(int i = 0;i < processes;++i)
  {
    work_plus_allocation[i] = (int*)malloc(sizeof(int) * resource_types);
    for(int j = 0;j < resource_types;++j)
    {
      work_plus_allocation[i][j] = -1;
    }
  }
  int* security_queue = (int*)malloc(sizeof(int) * processes);
  for(int i = 0;i < processes;++i)
  {
    security_queue[i] = i;
  }
  print_current_state(processes,resource_types,available,security_queue,max,allocation,need,work_plus_allocation);
  free_resouce(work_plus_allocation,processes);
  free((void*)security_queue);
  /* To peek initial state */
  int is_security;
  /* Test whether time t0 is safe */
  is_security = security_testing(resource_types,processes,available,max,need,allocation);
  if(is_security == False)
  {
    printf("The initial state is unsafe\n");
  }
  else
  {
    printf("Initial state security\n");
  }
  /* Making requests */
  //enum State state = request_resources(processes,resource_types,available,max,allocation,need);
  if(is_security)
  {
    // Request 5 times
  /*
    for(int i = 0;i < 5;++i)
    {
      enum State state = request_resources(processes,resource_types,available,max,allocation,need);
      if(state == Error)
      {
        printf("Error\n");
      }
      else if(state == Block)
      {
        printf("Block\n");
      }
      else
      {
        printf("Success\n");
      }
    }
  */
    enum State state = request_resources(processes,resource_types,available,max,allocation,need);
    if(state == Error) printf("Error\n");
    else if(state == Block) printf("Block\n");
    else printf("Success\n");
  }
  /* Free resources*/
  free((void*)resource_total);
  free((void*)resource_total_copy);
  free((void*)available);
  free_resouce(max,processes);
  free_resouce(allocation,processes);
  free_resouce(need,processes);
  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; }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值