当前位置: 首页 > news >正文

建设银行网站打不井wordpress 评论 html代码

建设银行网站打不井,wordpress 评论 html代码,微信公众号是干什么用的,连锁销售官网实验目的 模拟实现死锁检测算法 实验内容 1、 输入: “资源分配表”文件,每一行包含资源编号、进程编号两项(均用整数表示,并用空格分隔开),记录资源分配给了哪个进程。 “进程等待表”文件&…

实验目的      

模拟实现死锁检测算法

实验内容

1、 输入:

“资源分配表”文件,每一行包含资源编号、进程编号两项(均用整数表示,并用空格分隔开),记录资源分配给了哪个进程。

“进程等待表”文件,每一行包含进程编号、资源编号两项(均用整数表示,并用空格分隔开),记录进程正在等待哪个资源。

下面是一个示例:

资源分配表:  

 1    1

   2    2  

 3    3

进程等待表:    

1    2    

2    3  

 3    1

2. 处理:    

 程序运行时,首先提示“请输入资源分配表文件的文件名:”,再提示“请输入进程等待表文件的文件名:”。     输入两个文件名后,程序将读入两个文件中的有关数据,并按照死锁检测算法进行检测。

3. 输出:    

第一行输出检测结果:有死锁或无死锁。    

第二行输出进程循环等待队列,即进程编号(如果有死锁)。

4. 文件名约定      

源程序名:resourceXXX.cpp或resourceXXX.c(依据所用语言确定)。    

输入文件名:由用户自行指定。    

结果输出文件名:resultXXX.txt  

  其中:XXX为学号。

5. 死锁检测算法概述:      

当任一进程Pj申请一个已被其他进程占用的资源ri时,进行死锁检测。检测算法通过反复查找进程等待表和资源分配表, 来确定进程Pj对资源ri的请求是否导致形成环路,若是,便确定出现死锁。

6. 测试说明:将事先准备好的一组文件(格式为*.txt),从中为每个程序随机指定一至三个作为输入文件 (被测试者需从键盘输入指定文件的文件名),并查看程序输出结果。

实验代码

#include <stdio.h>
#include <iostream>
#include <string.h>
#include <direct.h> using namespace std;#define MAX_PATH 20const int MAXQUEUE = 100; // 定义表的最大行数typedef struct node {int resource;int process;
} cell;cell occupy[MAXQUEUE];
int occupy_quantity;
cell wait[MAXQUEUE];
int wait_quantity;// 初始化函数
void initial() {int i;for (i = 0; i < MAXQUEUE; i++) {occupy[i].process = -1;occupy[i].resource = -1;wait[i].process = -1;wait[i].resource = -1;}occupy_quantity = 0;wait_quantity = 0;
}// 读数据文件
int readData() {char currentDir[MAX_PATH];_getcwd(currentDir, MAX_PATH);FILE *fp;char fname[20];int i;cout << "请输入资源分配表文件的文件名:" << endl;cin >> fname;if ((fp = fopen(fname, "r")) == NULL) {cout << "错误,文件打不开,请检查文件名:)" << endl;return 0;} else {while (!feof(fp)) {fscanf(fp, "%d %d", &occupy[occupy_quantity].resource, &occupy[occupy_quantity].process);occupy_quantity++;}fclose(fp);}cout << "请输入进程等待表文件的文件名:" << endl;cin >> fname;if ((fp = fopen(fname, "r")) == NULL) {cout << "错误,文件打不开,请检查文件名:)" << endl;return 0;} else {while (!feof(fp)) {fscanf(fp, "%d %d", &wait[wait_quantity].process, &wait[wait_quantity].resource);wait_quantity++;}fclose(fp);}// 输出所读入的数据cout << endl << endl << "输出所读入的数据" << endl;cout << "━━━━━━━━━━━━━━━━━━━━━━━" << endl;cout << "资源分配表" << endl;cout << "资源编号 进程编号" << endl;for (i = 0; i < occupy_quantity; i++) {cout << " " << occupy[i].resource << " " << occupy[i].process << endl;}cout << "───────────────────────" << endl;cout << "进程等待表" << endl;cout << "进程编号 资源编号" << endl;for (i = 0; i < wait_quantity; i++) {cout << " " << wait[i].resource << " " << wait[i].process << endl;}return 1;
}// 检测
void check() {int table[MAXQUEUE][MAXQUEUE];int table1[MAXQUEUE][MAXQUEUE];int i, j, k;int flag, t, p;int max_process;// 初始化表格for (i = 0; i < MAXQUEUE; i++) {for (j = 0; j < MAXQUEUE; j++) {table[i][j] = 0;table1[i][j] = 0;}}// 先找到进程最大编号max_process = -1;for (i = 0; i < occupy_quantity; i++) {if (occupy[i].process > max_process) {max_process = occupy[i].process;}}for (i = 0; i < wait_quantity; i++) {if (wait[i].process > max_process) {max_process = wait[i].process;}}for (i = 0; i < wait_quantity; i++) {for (j = 0; j < occupy_quantity; j++) {if (wait[i].resource == occupy[j].resource) {table[wait[i].process][occupy[j].process] = 1;table1[wait[i].process][occupy[j].process] = 1;}}}cout << "初始等待占用表:" << endl;for (i = 0; i < max_process + 1; i++) {for (j = 0; j < max_process + 1; j++) {cout << table[i][j] << " ";}cout << endl;}cout << endl;for (i = 0; i < max_process + 1; i++) {for (j = 0; j < max_process + 1; j++) {for (k = 0; k < max_process + 1; k++) {table[i][j] = table[i][j] || (table[i][k] && table[k][j]);}}}cout << "检测后的等待占用表:" << endl;for (i = 0; i < max_process + 1; i++) {for (j = 0; j < max_process + 1; j++) {cout << table[i][j] << " ";}cout << endl;}flag = -1;for (i = 0; i < max_process + 1; i++) {if (table[i][i] == 1) {flag = i;break;}}cout << endl << endl << "检测结果" << endl;cout << "───────────────────" << endl;if (flag!= -1) {cout << "存在死锁" << endl;cout << "进程循环等待队列:";p = flag; // 存在进程循环等待队列的那一进程// 进程循环等待队列中的所有进程是 table 表中的这一行是 1 的进程,只是顺序要再确定t = 1;while (t) {cout << p << " ";for (j = 0; j < max_process + 1; j++) {if (table1[p][j] == 1) {if (table[j][flag] == 1) {p = j;break;}}}if (p == flag) t = 0;}cout << flag << endl;} else {cout << "不存在死锁" << endl;}
}// 显示版权信息函数
void version() {cout << endl << endl;cout << " ┏━━━━━━━━━━━━━━━━━━━━━━━┓" << endl;cout << " ┃      死 锁 检 测 算 法          ┃" << endl;cout << " ┠───────────────────────┨" << endl;cout << " ┃   (c)All Right Reserved Neo          ┃" << endl;cout << " ┃      sony006@163.com          ┃" << endl;cout << " ┃     version 2004 build 1122       ┃" << endl;cout << " ┗━━━━━━━━━━━━━━━━━━━━━━━┛" << endl;cout << endl << endl;
}int main() {int flag;version();initial();flag = readData();if (flag) check();return 0;
}

实验结果

afc08330cfd1484a8760c499e476537b.png

28889f1e0c8048f9b3400f1b6baf642a.png

 

 

http://www.yayakq.cn/news/65012/

相关文章:

  • 建设企业网站对公怎么再各网站上做宣传
  • 西安做网站报价百度关键词搜索量统计
  • 网站制作多久能完成做阿里巴巴英文网站
  • 做网站分辨率多少钱响应式网站的优缺点
  • sns社交网站.net源码邢台做网站推广报价
  • 太原网站建设口碑推荐上海网站建设规划
  • 博客做公司网站怎样用h5做网站
  • wordpress缓存头像品牌网站怎么做seo
  • 自己做网站需要学什么开封市建设中专网站
  • 口碑最好的网站建设99企业邮箱
  • 全屏网站表现形式开发公司采购部工作流程
  • 网站卡密代理怎么做网站建设学那些课程
  • 成都快速做网站NET网站开发程序员
  • 网站代企业网站建设要注意什么
  • c sql网站开发如何让新网站快速收录
  • 顶做抱枕网站成都企业建网站
  • 给网站做广告个人网站可以做论坛么
  • 网站建设的er图济宁市建设局网站
  • 凡科建站网址广东省做网站的公司
  • asp 网站管理工具单位如何建设网站
  • wordpress 网站静态页面大网站设计
  • 服装公司网站定位联合智慧旅游建设旅游门户网站
  • 家具网站建设的背景网站注销备案查询系统
  • 预付网站建设费用会计分录久久建筑网 百度网盘
  • 政务信息系统网站建设规范哪个网站可以找做中厚板的公司
  • 折叠网站开发工程师一级a做爰片视频免费观看网站
  • 网站的规划与建设案例分析旅行网站模板
  • 新鸿儒网站建设烟台网站建设求职简历
  • 静安做网站公司网站推广怎么样做
  • 重庆市做网站的公司九江网页设计公司