- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
----------专业最好文档,专业为你服务,急你所急,供你所需-------------
文档下载最佳的地方
----------专业最好文档,专业为你服务,急你所急,供你所需-------------
文档下载最佳的地方
操作系统课程设计-银行家算法(流程图+源代码+设计报告)
一、实验目的:熟悉银行家算法,理解系统产生死锁的原因及避免死锁的方法,加深记意。二、实验要求:用高级语言编写和调试一个描述银行家算法的程序。三、实验内容:1、 设计一个结构体,用于描述每个进程对资源的要求分配情况。包括:进程名——name[5],要求资源数目——command[m](m类资源),还需要资源数目——need[m],已分配资源数目——allo[m]。2、 编写三个算法,分别用以完成:①申请资源;②显示资源;③释放资源。(动态完成)四、程序流程图五、源程序:最新版本:bk5.c/*bk2.c::可以自定义进程及资源数目,可选择读文件或创建新文件,但不超过10,5*//*可修改# define NP 10*//* # define NS 5 */ /*资源种类*//*bk3.c::可以继续分配资源(〉2)*//*bk4.c::可保存分析结果*//*bk5.c::除以上功能外,对暂时不能分配的可以进行另外一次尝试,并恢复已分配的资源*//*四、程序流程图:
五、源程序:最新版本:bk5.c/*bk2.c::可以自定义进程及资源数目,可选择读文件或创建新文件,但不超过10,5*//*可修改# define NP 10*//* # define NS 5 */ /*资源种类*//*bk3.c::可以继续分配资源(〉2)*//*bk4.c::可保存分析结果*//*bk5.c::除以上功能外,对暂时不能分配的可以进行另外一次尝试,并恢复已分配的资源*/#include ?string.h#include ?stdio.h#include dos.h#include conio.h#define MOVEIN 1#define GUIYUE 2#define ACC 3#define OK 1#define ERROR 0#define MAXSH 7#define MAXSHL 10#define MAXINPUT 50#define ? maxsize ? 100int act;int ip=0;int ?line=0; ?/*line为要写的行号,全局变量*/int writeok;int right;char wel[30] = {Welcome To Use An_Li System};char ente[76]={ 警告:未经作者同意不得随意复制更改!};char rights[40]={Copyright (c) 2002};struct date today;struct time now;typedef struct{int data[maxsize];?int top;?}stack;int emptystack(stack *S){if(S-top==48S-data[S-top]==35)return(1); ?/*35 is #*/?else return(0);}int push(stack *S,int x){if(S-top=maxsize-1)return(-1);else{S-top++;? ? ?S-data[S-top]=x;? ? ?return(0);? ? }}int gettop(stack *S){return S-data[S-top];}int pop(stack *S){if(emptystack(S)){printf(the stack is empty\n);exit(1);}?else S-top--;return S-data[S-top+1];?}void initstack(stack *S){int i;S-top=0;S-data[S-top]=35;}/*****模拟打字机的效果*********/delay_fun(){? ?int i;? ?void music(); ?? ?for(i=0;;i++)? ?{? ? ? if(wel!=\0)? ? ? {? ? ?? ? delay(1000);? ? ?? ? textcolor(YELLOW);? ? ?? ? gotoxy(26+i,8);? ? ?? ? cprintf(%c,wel);printf(谢谢);print
文档评论(0)