




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年事业单位工勤技能-浙江-浙江假肢制作装配工一级(高级技师)历年参考题库含答案解析(5套)
- 2025年事业单位工勤技能-河南-河南水文勘测工三级(高级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-河南-河南护理员五级(初级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-河南-河南印刷工一级(高级技师)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-河北-河北药剂员四级(中级工)历年参考题库含答案解析(5套)
- 2025年事业单位工勤技能-河北-河北林木种苗工四级(中级工)历年参考题库含答案解析
- 2025年事业单位工勤技能-江西-江西放射技术员二级(技师)历年参考题库含答案解析(5套)
- 2025年事业单位工勤技能-江西-江西中式烹调师四级(中级工)历年参考题库含答案解析(5套)
- 2025年事业单位工勤技能-广西-广西有线广播电视机务员三级(高级工)历年参考题库含答案解析
- 2025年事业单位工勤技能-广西-广西垃圾清扫与处理工一级(高级技师)历年参考题库典型考点含答案解析
- 中国茶文化双语故事课件
- GB/T 45411.2-2025光学和光子学瞄准望远镜规范第2部分:高性能仪器
- 少数民族民歌 课件-2024-2025学年高一上学期音乐人音版(2019)必修音乐鉴赏
- Android移动应用开发(微课版)全套教学课件
- 腰椎间盘突出症试讲教案
- 钢旋转楼梯施工方案
- 2025-2031年中国手抓饼行业市场全景调研及投资规划建议报告
- 计算机信息安全管理培训
- 电动车充电桩调研报告
- 合同能源管理epc合同范本
- 2025年天翼云解决方案架构师认证考试指导题库-下(多选、判断题)
评论
0/150
提交评论