c从文件读取数据,实现银行家算法

银行家算法

针对多类资源分配的情况,最著名的而是银行家算法,银行家算法的设计思想是:当用户申请一组资源时,系统必须做出判断;如果把这些资源分出去,系统是否还处于安全状态。若是,就可以分出这些资源;否则,该申请暂不予满足。
实现银行家算法要有若干数据结构,用来表示资源分配系统的状态。

  • 其中,n表示系统中进程的数目。M表示资源分类数。

  • Avaliable是一个长度为m的向量,表示每一类资源可用的数量。Avaliable[j]=k,表示rj类资源可用的数量是k

  • Max是一个n*m矩阵,表示每个进程对资源的最大需求。Max[i,j]=k,表示进程pi至多课申请k个rj类资源单位

  • Allocation是一个n*m的矩阵,表示当前分给每个进程的资源数目,Allocation[i,j]=k,表示进程pi当前分到k个rj类资源

  • Need是一个n*m矩阵,他表示每个进程还缺少多少资源。Need[i,j]=k,表示进程pj尚需k个rj类资源才能完成其任务。显然,Need[i,j]=Max[i,j]-Allocation[i,j]

  • Request 是一个n*m矩阵,i表示进程pi申请向量,Request[i][j]=k表示进程pi需要申请k个rj类资源

从文件读取数据银行家算法的验证数据文件data格式说明

验证数据:建立在程序目录下建立data文件,文件内容是:
5 3
10 5 7
0 0 1 0 7 5 3
1 2 0 0 3 2 2
2 3 0 2 9 0 2
3 2 1 1 2 2 2
4 0 0 2 4 3 3

1 1 0 2
4 3 3 0
0 0 2 0
第一行:5个进程,3种资源。
第二行:每种资源系统拥有的最大数量。
3-7行:第一列是进程号(按顺序排),2-4列是Request(资源请求)向量,5-7列是Max(最大资源需求量)向量。
8-10行:第一列是进程号,2-4列是Request(资源请求)向量。

运行程序,通过命令行参数指定文件,如: ./banker ./data运行。

代码

/**
 * lzy
 */
#include <stdio.h>
#include <unistd.h>

#define maxNum 100
#define maxLineNum 100
// 定义一个文件指针全局变量
FILE *fpl;
// 定义一个储存文件一行的数组
char line[maxLineNum];
//定义一个数组用来储存提取的字符
int lineData[maxLineNum];
// 定义一个数组来保存进程名,如processBox[1] = 2表示下标为1时,对应的进程名为2
int processBox[maxNum];
// 安全性算法需要用到的Work,Finish数组
int Work[maxNum];
int Finish[maxNum];
// 定义进程数目,定义资源分类数
int n, m;
int Resource[maxNum] = {
   0};
int Available[maxNum] = {
   0};
int Max[100][maxNum] = {
   0};
int Allocation[maxNum][maxNum] = {
   0};
int Need[maxNum][maxNum] = {
   0};
int Request[maxNum][maxNum] = {
   0};
char firstLetter;

/**
 * 读取line一行的数据到数组lineData中
 * @param num 提取个数
 */
void updateLineData(int num) {
   
    firstLetter = line[0];

    int nape;
    int cursor = 0;
    for (int i = 0; i < num; ++i) {
   
        nape = 0;
        while ((int) line[cursor] != 32 && (int) line[cursor] != 0 && (int) line[cursor] != 10) {
   
            nape = nape * 10 + (int) line[cursor] - 48;
            ++cursor;
        }

        ++cursor;
        lineData[i] = nape;
    }
}

/**
 * 初始化数据函数,
 * @param src ,目标文件目录
 */
void lzyInitData(char *src) {
   
    // 1.初始化文件指针
    fpl = fopen(src, "r");
    if (fpl == NULL) {
   
        printf("lzy:文件读取失败,没有这个文件");
        _exit(-1);
    }

    // 2.读取文件,初始化各种全局变量
    // 2.1初始化n、m
    fgets(line, maxLineNum, fpl);
  • 3
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
银行家算法可以通过文件输入输出实现,具体步骤如下: 1.首先,需要建立银行家算法数据结构描述,包括进程数、资源数、可用资源数、已分配资源数、需求资源数等信息。 2.将初始数据放在文件中,算法运行时读出。可以使用Python中的open()函数打开文件,使用read()函数读取文件内容,并使用split()函数将文件内容分割成需要的数据结构。 3.对给定的资源请求,使用算法判断是否允许。可以使用Python中的if语句判断请求是否合法,并根据算法的判断结果输出相应的信息。 4.输出每次判断产生的执行序列。可以使用Python中的print()函数输出每次判断的执行序列。 下面是一个简单的Python实现示例: ```python # 读取文件中的数据 with open('data.txt', 'r') as f: data = f.read().split('\n') process_num = int(data[0]) resource_num = int(data[1]) available = list(map(int, data[2].split())) max_claim = [list(map(int, data[i].split())) for i in range(3, 3+process_num)] allocation = [list(map(int, data[i].split())) for i in range(3+process_num, 3+2*process_num)] need = [[max_claim[i][j] - allocation[i][j] for j in range(resource_num)] for i in range(process_num)] # 判断资源请求是否合法 def is_safe(process_id, request): global available, allocation, need for i in range(resource_num): if request[i] > need[process_id][i] or request[i] > available[i]: return False return True # 处理资源请求 def request_resource(process_id, request): global available, allocation, need if is_safe(process_id, request): for i in range(resource_num): available[i] -= request[i] allocation[process_id][i] += request[i] need[process_id][i] -= request[i] return True else: return False # 输出每次判断产生的执行序列 def print_sequence(): global available, allocation, need sequence = [] work = available.copy() finish = [False] * process_num while False in finish: flag = False for i in range(process_num): if not finish[i] and all([need[i][j] <= work[j] for j in range(resource_num)]): sequence.append(i) for j in range(resource_num): work[j] += allocation[i][j] finish[i] = True flag = True if not flag: return [] return sequence # 处理资源请求并输出执行序列 request = [1, 0, 2] if request_resource(0, request): print("Request is granted.") print("Execution sequence:", print_sequence()) else: print("Request is denied.") ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值