已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
题目:设计一个按优先数调度算法实现处理器调度的程序提示:(1)假定系统有 5 个进程,每个进程用一个 PCB 来代表。PCB 的格式为:进程名、指针、要求运行时间、优先数、状态。进程名P1P5。指针按优先数的大小把 5 个进程连成队列,用指针指出下一个进程 PCB 的首地址。要求运行时间假设进程需要运行的单位时间数。优先数赋予进程的优先数,调度时总是选取优先数大的进程先执行。状态假设两种状态,就绪,用 R 表示,和结束,用 E 表示。初始状态都为就绪状态。(2) 每次运行之前,为每个进程任意确定它的“优先数” 和“要求运行时间” 。(3) 处理器总是选队首进程运行。采用动态改变优先数的办法,进程每运行 1 次,优先数减 1,要求运行时间减 1。(4) 进程运行一次后,若要求运行时间不等于 0,则将它加入队列,否则,将状态改为“结束” ,退出队列。(5) 若就绪队列为空,结束,否则,重复(3)。2程序中使用的数据结构及符号说明:#define num 5/假定系统中进程个数为 5 struct PCBchar ID;/进程名int runtime;/要求运行时间int pri;/优先数char state; /状态,R-就绪,F-结束;struct PCB pcblistnum;/定义进程控制块数组3流程图:(1)主程序流程图: (2)子程序 init()流程图:调用初始化子程序调用运行子程序结 束开 始开 始定义 ii=0inum输出操作提示输入 ID,pri,runtimestate=Rgetchar()结束i=i+1(3) 子程序 max_pri_process()流程图:开始定义 i,key,max=100i=0inumpcblisti.state=rmaxpcblisti.pri/进程名int runtime;/要求运行时间int pri;/优先数char state; /状态,R-就绪,F-结束;struct PCB pcblistnum;/定义进程控制块数组void init()/PCB 初始化子程序int i;for(i=0;inum;i+)printf(“PCB%d:ID pri runtime n“,i+1);/为每个进程任意指定 pri 和 runtimescanf(“%s%d%d“,pcblisti.state=R;/进程初始状态均为就绪getchar();/接收回车符int max_pri_process()/确定最大优先级进程子程序int max=-100;/max 为最大优先数,初始化为-100int i;int key;for(i=0;inum;i+)if(pcblisti.state=r)/r 为辅助状态标志,表示正在运行return -1;/返回-1elseif(maxpcblisti.pri/max 存放每次循环中的最大优先数key=i;/将进程号赋给 keyif(pcblistkey.state=F)/具有最大优先数的进程若已运行完毕return -1;/则返回-1else/否则return key;/将 key 作为返回值返回void show()/显示子程序int i;printf(“n ID pri runtime staten“);printf(“-n“);for(i=0;inum;i+)/依次显示每个进程的名、优先数、要求运行时间和状态printf(“%s%6d%8d %sn“,printf(“ press any key to continue.n“);void run()/进程运行子程序int i,j;int t=0;/t 为运行次数for(j=0;jnum;j+)t+=pcblistj.runtime;/运行次数即为各个进程运行时间之和printf(“nbefore run,the conditon is:n“);show(); /调用 show()子程序显示运行前 PCB 的情况getchar();/等待输入回车符for(j=0;jt;j+) while(max_pri_process()!=-1)/具有最大优先数的进程没有运行完,让其运行 pcblistmax_pri_process().state=r;/将其状态置为 r,表示其正在运行 for(i=0;inum;i+)if(pcblisti.state=r) pcblisti.pri-=1;/将当前运行进程的优先数减 1pcblisti.runtime-;/要求运行时间减 1if(pcblisti.runtime=0)pcblisti.state=F;/运行完则将该进程状态置为结束elsepcblisti.state=R;/未运行完将其状态置为就绪
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026届湖北省枣阳五中学物理九年级第一学期期末调研模拟试题含解析
- 重庆市沙坪坝区第八中学2026届物理九年级第一学期期末预测试题含解析
- 2026届宁夏固原市名校物理八上期末综合测试模拟试题含解析
- 2026届北京市101中学物理八上期末经典模拟试题含解析
- 辽宁省沈阳市沈河区第八十二中学2026届九上物理期中教学质量检测模拟试题含解析
- 物业社区服务质量标准方案
- 户外野营炊具创新设计项目分析方案
- 跨平台兼容性测试项目分析方案
- 自助加油设备升级项目分析方案
- 婴儿配方奶粉生产线升级项目分析方案
- 2025年完整版零星维修工程施工方案服务投标标书
- 医院患者隐私保护制度及培训讲义
- 华师大(2024)数学八上12.2.1 全等三角形的判定条件 课件
- 黑龙江省安全文明施工费管理办法
- 《Unit 3 Visit to the farm》(教学设计)-科普版(2024)英语三年级上册
- 玻尿酸水光臻颜套课件
- 市政工程监理安全文明施工交底书
- 防秋乏知识培训材料课件
- 2025年新海龟汤题目及答案
- 高职院校就业指导课程教学设计
- 医学生职业生涯发展报告
评论
0/150
提交评论