汐ya~ 2022-12-04 23:44 采纳率: 87.8%
浏览 54
已结题

C++ 操作系统 怎么把FCFS算法与银行家算法结合一起

C++ 操作系统 怎么把FCFS算法与银行家算法结合一起,
有没有哪位能给点思路怎么去实现这个问题呀?代码放在下面了

img

img

FCFS算法代码

#include<iostream>
#include<string>
#include<queue>
using namespace std;
typedef struct pcb {
    string pName;  //进程名
    float arriveTime;//到达时间
    float serviceTime;//服务时间
    float estimatedRunningtime;//估计运行时间
    float startTime;//开始运行时间
    float finishTime;//完成运行时间
    float turnaroundTime;//周转时间
    float weightedTuraroundTime;//带权周转时间
    char state;//状态
    bool operator<(const pcb &a)const {
        return arriveTime > a.arriveTime;
    }
}PCB;

void createProcess(priority_queue<PCB> &p, int n) {//创建n个进程
    cout << endl << endl << "创建进程" << endl;
    PCB r;//工作结点
    for (int i = 0; i<n; i++) {
        cout << "请输入第" << i + 1 << "个进程的名字、到达时间、服务时间(例如:A 12 8):";
        cin >> r.pName;
        cin >> r.arriveTime;
        cin >> r.serviceTime;
        r.startTime = 0;
        r.finishTime = 0;
        r.estimatedRunningtime = r.serviceTime;
        r.turnaroundTime = 0;
        r.weightedTuraroundTime = 0;
        p.push(r);
    }
}

void printProcess(priority_queue<PCB> p) {//输出所有进程的信息
    PCB q;
    cout << "进程名\t到达时间 服务时间 开始时间 完成时间 周转时间 带权周转时间" << endl;
    while (p.size() != 0) {
        q = p.top();
        cout << q.pName << "\t" << q.arriveTime << "\t " << q.serviceTime << "\t  ";
        cout << q.startTime << "\t   " << q.finishTime << "\t    " << q.turnaroundTime << "\t     " << q.weightedTuraroundTime << endl;
        p.pop();
    }
    cout << endl << endl;
}

void runProcess(priority_queue<PCB> &p, priority_queue<PCB> &q, int n) {//运行进程
    PCB s;
    float finishTimeOfPriorProcess;
    for (int i = 0; i<n; i++) {
        s = p.top();
        if (i == 0) {//当前进程是第一个进程
            while (s.estimatedRunningtime != 0) {//输出当前运行进程的信息
                cout << "正在运行的进程" << endl;
                cout << "进程名\t到达时间 服务时间 已运行时间 还剩运行时间" << endl;
                cout << s.pName << "\t" << s.arriveTime << "\t " << s.serviceTime << "\t  ";
                cout << s.serviceTime - s.estimatedRunningtime << "\t     " << s.estimatedRunningtime << endl;
                s.estimatedRunningtime--; //当前进程的估计运行时间减1
            }
            s.startTime = s.arriveTime;
            s.finishTime = s.startTime + s.serviceTime;
            s.turnaroundTime = s.finishTime - s.arriveTime;
            s.weightedTuraroundTime = float(s.turnaroundTime*1.0 / s.serviceTime);
            s.state = 'C';
            finishTimeOfPriorProcess = s.finishTime;
        }
        else {//当前进程不是第一个进程
            while (s.estimatedRunningtime != 0) {
                cout << "正在运行的进程" << endl;
                cout << "进程名\t到达时间 服务时间 已运行时间 还剩运行时间" << endl;
                cout << s.pName << "\t" << s.arriveTime << "\t " << s.serviceTime << "\t  ";
                cout << s.serviceTime - s.estimatedRunningtime << "\t     " << s.estimatedRunningtime << endl;
                s.estimatedRunningtime--;//当前进程的估计运行时间减1

            }
            s.startTime = finishTimeOfPriorProcess>s.arriveTime ? finishTimeOfPriorProcess : s.arriveTime;
            s.finishTime = s.startTime + s.serviceTime;
            s.turnaroundTime = s.finishTime - s.arriveTime;
            s.weightedTuraroundTime = float(s.turnaroundTime*1.0 / s.serviceTime);
            s.state = 'C';
            finishTimeOfPriorProcess = s.finishTime;
        }
        q.push(s);
        p.pop();
        cout << "进程" << s.pName << "执行结束之后就绪队列中的进程" << endl;
        printProcess(p);
    }
    cout<< endl << endl;
}

int main() {
    priority_queue<PCB> p,q;
    int n;
    cout << "请输入进程的个数:";
    cin >> n;
    createProcess(p, n);
    runProcess(p, q, n);
    cout << "所有进程执行结束之后的相关情况" << endl << endl;
    printProcess(q);
    getchar();
    getchar();
    return 0;
}

银行家算法代码


#include <stdio.h>
#include <string.h>
#define False 0
#define True 1
#define Process_num 5 //系统中所有进程数量
typedef struct {
    int r1;
    int r2;
    int r3;
}Resource;
//最大需求矩阵
Resource Max[Process_num] =
        { {6,4,3}, {3,2,4}, {9,0,3}, {2,2,2}, {3,4,3} };
//已分配资源数矩阵
Resource Allocation[Process_num] =
        { {1,1,0}, {2,0,1}, {4,0,2}, {2,1,1}, {0,1,2} };
//需求矩阵
Resource Need[Process_num] =
        { {5,3,3}, {1,2,3}, {5,0,1}, {0,1,1}, {3,3,1} };
//可用资源向量
Resource Available = {3,3,2};
int safe[Process_num];
//试探分配
void ProbeAlloc(int process, Resource *res)
{
    Available.r1 -= res->r1;
    Available.r2 -= res->r2;
    Available.r3 -= res->r3;
    Allocation[process].r1 += res->r1;
    Allocation[process].r2 += res->r2;
    Allocation[process].r3 += res->r3;
    Need[process].r1 -= res->r1;
    Need[process].r2 -= res->r2;
    Need[process].r3 -= res->r3;
}
//若试探分配后进入不安全状态,将分配回滚
void RollBack(int process, Resource *res)
{
    Available.r1 += res->r1;
    Available.r2 += res->r2;
    Available.r3 += res->r3;
    Allocation[process].r1 -= res->r1;
    Allocation[process].r2 -= res->r2;
    Allocation[process].r3 -= res->r3;
    Need[process].r1 += res->r1;
    Need[process].r2 += res->r2;
    Need[process].r3 += res->r3;
}
//安全性检查
int SafeCheck()
{
    Resource Work = Available;
    int Finish[Process_num] = {False, False, False, False, False};
    int i, j = 0;
    for (i = 0; i < Process_num; i++)
    {
        //是否已检查过
        if(Finish[i] == False)
        {
            //是否有足够的资源分配给该进程
            if(Need[i].r1<=Work.r1 && Need[i].r2<=Work.r2 &&
               Need[i].r3<=Work.r3)
            {
                //有则使其执行完成,并将已分配给该进程的资源全部回收
                Work.r1 += Allocation[i].r1;
                Work.r2 += Allocation[i].r2;
                Work.r3 += Allocation[i].r3;
                Finish[i] = True;
                safe[j++] = i;
                i = -1; //重新进行遍历
            }
        }
    }
//如果所有进程的Finish向量都为true则处于安全状态,否则为不安全状态
    for (i = 0; i < Process_num; i++)
    {
        if (Finish[i] == False)
        {
            return False;
        }
    }
    return True;
}
//资源分配请求
int Request(int process, Resource *res)
{
//request向量需小于Need矩阵中对应的向量
    if(res->r1 <= Need[process].r1 && res->r2 <= Need[process].r2 &&
       res->r3 <= Need[process].r3)
    {
        //request向量需小于Available向量
        if(res->r1 <= Available.r1 && res->r2 <= Available.r2 &&
           res->r3 <= Available.r3)
        {
            //试探分配
            ProbeAlloc(process, res);
            //如果安全检查成立,则请求成功,否则将分配回滚并返回失败
            if(SafeCheck())
            {
                return True;
            }
            else
            {
                printf("安全性检查失败。原因:系统将进入不安全状态,有可能引起死锁。\n");
                printf("正在回滚...\n");
                RollBack(process, res);
            }
        }
        else
        {
            printf("安全性检查失败。原因:请求向量大于可利用资源向量。\n");
        }
    }
    else
    {
        printf("安全性检查失败。原因:请求向量大于需求向量。\n");
    }
    return False;
}
//输出资源分配表
void PrintTable()
{
    printf("\t\t\t*********资源分配表*********\n");
    printf("Process Max Allocation Need Available\n");
    printf(" r1 r2 r3 r1 r2 r3 r1 r2 r3 r1 r2 r3\n");
    printf(" P0 %d %d %d %d %d %d %d %d %d %d%d%d\n",Max[0].r1,Max[0].r2,Max[0].r3,Allocation[0].r1,Allocation[0].r2,Allocation[0].r3,
    Need[0].r1,Need[0].r2,Need[0].r3,Available.r1,Available.r2,Available.r3);
    printf(" P1 %d %d %d %d %d %d %d %d%d\n",Max[1].r1,Max[1].r2,Max[1].r3,Allocation[1].r1,Allocation[1].r2,Allocation[1].r3,
    Need[1].r1,Need[1].r2,Need[1].r3);
    printf(" P2 %d %d %d %d %d %d %d %d%d\n",Max[2].r1,Max[2].r2,Max[2].r3,Allocation[2].r1,Allocation[2].r2,Allocation[2].r3,
    Need[2].r1,Need[2].r2,Need[2].r3);
    printf(" P3 %d %d %d %d %d %d %d %d%d\n",Max[3].r1,Max[3].r2,Max[3].r3,Allocation[3].r1,Allocation[3].r2,Allocation[3].r3,
    Need[3].r1,Need[3].r2,Need[3].r3);
    printf(" P4 %d %d %d %d %d %d %d %d%d\n",Max[4].r1,Max[4].r2,Max[4].r3,Allocation[4].r1,Allocation[4].r2,Allocation[4].r3,
    Need[4].r1,Need[4].r2,Need[4].r3);
    printf("\n");
}
int main()
{
    int ch;
    printf("先检查初始状态是否安全。\n");
    if (SafeCheck())
    {
        printf("系统处于安全状态。\n");
        printf("安全序列是{P%d,P%d,P%d,P%d,P%d}。\n",safe[0],safe[1],safe[2],safe[3],safe[4]);
    }
    else
    {
        printf("系统处于不安全状态。程序将退出...\n");
        printf("执行完毕。");
        return 0;
    }
    do
    {
        int process;
        Resource res;
        PrintTable();
        printf("请依次输入请求分配的进程和对三类资源的请求数量:\n");
        scanf("%d%d%d%d",&process,&res.r1,&res.r2,&res.r3);
        if (Request(process, &res))
        {
            printf("分配成功。\n");
            printf("安全序列是{P%d,P%d,P%d,P%d,P%d}。\n",safe[0],safe[1],safe[2],safe[3],safe[4]);
        }
        else
        {
            printf("分配失败。\n");
        }
        printf("是否继续分配?(Y/N):");

        ch = getchar();
        ch = getchar();
    } while (ch == 'Y' || ch == 'y');
    return 0;
}

  • 写回答

0条回答 默认 最新

    报告相同问题?

    问题事件

    • 系统已结题 12月12日
    • 创建了问题 12月4日

    悬赏问题

    • ¥15 时间序列预测算法 预测结果出现负值
    • ¥15 苹果mac m1系统在关闭sip后怎么能使用app
    • ¥15 在win系统Django虚拟环境下载mysqlclient报错
    • ¥15 pg数据库导入数据序列重复
    • ¥15 三分类机器学习模型可视化分析
    • ¥15 本地测试网站127.0.0.1 已拒绝连接,如何解决?(标签-ubuntu)
    • ¥50 Qt在release捕获异常并跟踪堆栈(有Demo,跑一下环境再回答)
    • ¥30 python,LLM 文本提炼
    • ¥15 关于将inet引入的相关问题
    • ¥15 关于一个倒计时的操作和显示设计