c++银行家算法
#include <iostream> #include<string> #define False 0 #define True 1 using namespace std; ] = { }; //系统->拥有资源 ][] = { }; //进程->共需要 ][] = { }; //进程->已得到 ][] = { }; //进程->还需要 ] = { }; //模拟->系统->拥有资源 //int Request[100] = { 0 }; //进程->请求资源 0.0貌似后来没用到 ] = { }; //资源名称。界面使用 ] = { }; //存放安全序列 ; //进程的最大数为 ; //资源的最大数为 void showdata(); //显示资源矩阵 int safe(); //安全性算法 int main()//主函数 { , m, n, flag; char ming; //------------------------------------------------------------->>>>>>>> 【界面】 >>> cout << "\t*-----------------------------------------------------*" << endl; cout << "\t|| ||" << endl; cout << "\t|| 银行家算法实现 ||" << endl; cout << "\t|| ||" << endl; cout << "\t|| 张金棒 ||" << endl; cout << "\t|| ||" << endl; cout << "\t|| 2016.06.29 ||" << endl; cout << "\t|| ||" << endl; cout << "\t*-----------------------------------------------------*" << endl; //------------------------------------------------------------->>>>>>>> 【初始化】 >>> cout << "请先输入系统可供资源种类的数量:"; cin >> n; N = n; ; i < n; i++) { cout << << "的名称:"; cin >> ming; name[i] = ming; cout << "资源的数量:"; cin >> number; Avaliable[i] = number; } cout << endl; cout << "请输入作业的数量"; cin >> m; M = m; cout << "请输入各进程的最大需求量(" << m << "*" << n << "矩阵)[Max]:" << endl; ; i < m; i++) ; j < n; j++) cin >> Max[i][j]; do { flag = ; cout << "请输入各进程已经申请的资源量(" << m << "*" << n << "矩阵)[Allocation]:" << endl; ; i < m; i++) ; j < n; j++) { cin >> Allocation[i][j]; ; Need[i][j] = Max[i][j] - Allocation[i][j]; Avaliable[j] = Avaliable[j] - Allocation[i][j]; } if (flag) cout << "申请的资源大于最大需求值,请重新输入!\n"; } while (flag); showdata();//显示各种资源 safe();//用银行家算法判定系统是否安全 system("pause"); ; } //------------------------------------------------------------->>>>>>>> 【界面·显示资源矩阵】 >>> void showdata() { int i, j; cout << "系统当前可用资源[Avaliable]:" << endl; ; i < N; i++) cout << name[i] << " "; cout << endl; ; j < N; j++) cout << Avaliable[j]<<" "; cout << endl; cout << " Max Allocation Need" << endl; cout << "process "; ; j < ; j++) { ; i < N; i++) cout << name[i] << " "; cout << " "; } cout << endl; ; i < M; i++) { cout << " " << i << " "; ; j < N; j++) cout << Max[i][j] << " "; cout << " "; ; j < N; j++) cout << Allocation[i][j] << " "; cout << " "; ; j < N; j++) cout << Need[i][j] << " "; cout << endl; } } //------------------------------------------------------------->>>>>>>> 【银行家算法】 >>> int safe() { , m, apply, Finish[] = { }; //apply [应用,使用] int j; ; i < N; i++) { Work[i] = Avaliable[i]; } ; i < M; i++)//------------------------------------->>>>>>>>>>选定进程 i { apply = ; ; j < N; j++)//--------------------------------->>>>>>>>>>选定资源 j { if (Finish[i] == False&&Need[i][j] <= Work[j])//------>>>>>>>>>>第i个进程j类所需资源小于系统拥有的资源 { apply++; if (apply == N)//--------------------------------->>>>>>>>>>当i进程各类资源都满足后 { ; m < N; m++) Work[m] = Work[m] + Allocation[i][m];//--->>>>>>>>>>分配其资源使其运行结束然后回收资源 Finish[i] = True;//--------------------------->>>>>>>>>>i进程执行完毕 temp[k] = i;//-------------------------------->>>>>>>>>>写入进程号到序列中 i = -;//------------------------------------->>>>>>>>>>检查前面的是否有可满足的 k++;//---------------------------------------->>>>>>>>>>准备好写下一个安全序列项 } } } } ; i < M; i++) { if (Finish[i] == False) { cout << "系统不安全" << endl;//不成功 系统不安全 ; } } cout << "系统是安全的!" << endl;//如果安全,输出成功 cout << "分配的序列:"; ; i < M; i++) //输出运行进程的数组 { cout << temp[i]; ) cout << "->"; } cout << endl; ; }
c++银行家算法的更多相关文章
- 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++程序
此程序在Windows10 CodeBlocks17.12环境下测试运行,其他编程环境未经测试! 作业需求↓↓↓↓↓↓ 运行效果图如下 (codeblocks下载地址http://www.cod ...
- python模拟银行家算法
前言: 大二第一学期学习了操作系统,期末实验课题要求模拟算法.遂根据自己学习的python写下此文.以此锻炼自己编码能力.虽说是重复造轮子,但还是自己的思路体现 代码及注释如下(银行家算法不再赘述): ...
- 预防和避免死锁的方法及银行家算法的java简单实现
预防死锁 (1) 摒弃"请求和保持"条件 基本思想:规定所有进程在开始运行之前,要么获得所需的所有资源,要么一个都不分配给它,直到所需资源全部满足才一次性分配给它. 优点:简单.易 ...
- Round() 四舍五入 js银行家算法
首先问一下round(0.825,2) 返回的结果,大家猜一猜, 首先SQL server 返回的是 0.83 js的返回结果 是0.83,code 如下: var b = 0.825; ...
- C程序模拟实现银行家算法
C程序模拟实现银行家算法 上周又做操作系统实验,题目是用程序模拟实现银行家算法,写了半天还真有点晕,主要是因为想尽可能符合课本上的描述,所以写出来的程序就比较恶心了,好了,银行家算法就不多说了,不了解 ...
随机推荐
- Spring Security 入门(1-4-1)Spring Security - 认证过程
理解时可结合一下这位老兄的文章:http://www.importnew.com/20612.html 1.Spring Security的认证过程 1.1.登录过程 - 如果用户直接访问登录页面 用 ...
- Error loading MySQLdb module: No module named 'MySQLdb'----------- django成功连接mysql数据库的方法
在进行django学习过程中,尝试使用框架连接mysql数据库,启动服务器的时候经常遇到Error loading MySQLdb module: No module named 'MySQLdb' ...
- leetcode算法:Trim a Binar Search Tree
Given a binary search tree and the lowest and highest boundaries as L and R, trim the tree so that a ...
- IIS进行URL重写
一.Why? 1.先来讲一讲为什么我们要使用url重写这个东西 2.因为我学习的后端是nodejs,然后我发现nodejs一个非常让人难受的事,就是它监听端口不是80和443时,你访问网页需要输入端口 ...
- MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)
本节演示如何为 MySQL 数据库提供持久化存储,步骤为: 创建 PV 和 PVC. 部署 MySQL. 向 MySQL 添加数据. 模拟节点宕机故障,Kubernetes 将 MySQL 自动迁移到 ...
- html标记语言 --表单
html标记语言 --表单 七.表单 1.表单标记 1.1表单中的内容 <form></form>定义表单的开始位置和结束位置,表单提交时的内容就是<form>表单 ...
- Flume报 Space for commit to queue couldn't be acquired. Sinks are likely not keeping up with sources, or the buffer size is too tight
报这个错误 需要一个是flume堆内存不够.还有一个就是把channel的容器调大 在channel加配置 type - 组件类型名称必须是memory capacity 100 存储在 Channe ...
- fiddler实现手机抓包
对fiddler相关配置 1.允许fiddler捕获http协议,打开fiddler客户端,菜单框选择Tools->Options->HTTPS,勾选图中三项 2.允许远程连接,Tools ...
- 自动化运维:使用flask+mysql+highcharts搭建监控平台
1.前言 本来想做一个比较完善的监控平台,只需要做少许改动就可以直接拿来用,但是在做的过程中发现要实现这个目标所需的工作量太大,而当前的工作中对其需求又不是特别明显.所以就退而求其次,做了一个类似教程 ...
- sqlserver数据库导入Mysql数据库问题
近来遇到一个问题,之前的项目用的是SQLServer数据库,但是现在要换成MySQL数据库,所有整理了一些数据导入的步骤,供需要的人参考! 第一步: 第二步: 第三步: 第四步: 第五步: 第六步: ...