基于优先数的时间片轮转调度算法调度处理器_第1页
基于优先数的时间片轮转调度算法调度处理器_第2页
基于优先数的时间片轮转调度算法调度处理器_第3页
基于优先数的时间片轮转调度算法调度处理器_第4页
基于优先数的时间片轮转调度算法调度处理器_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

题目4基于优先数的时间片轮转调度算法调度处理器一、实验目的在采用多道程序设计的系统中,同时处于就绪态的进程往往有多个,当就绪态的进程数大于处理器的个数时,就需按照某种策略进行分配处理器。本次设计模拟在单处理器情况下采用基于优先数的时间片轮转调度算法进行处理器调度,加深了解处理器调度工作过程。二、实验内容及要求1、设计一个程序实现基于优先数的时间片轮转调度算法调度处理器。2、假定系统有5个进程,每个进程用一个进程控制块PCB开代表,进程控制块的结构如下图1.2所示:进程名指针到达时间要求运行时间已运行时间优先数进程状态图1其中:进程名:作为进程的标识。指针:进程按顺序排成循环链表,用指针指出下一个进程的进程控制块首地址,最后一个进程中的指针指出第一个进程的进程控制块首地址。要求运行时间:假设进程需要运行的单位时间数。已运行时间:假设进程已经运行的单位时间数,初值为0。状态:可假设有两种状态,就绪状态和结束状态。进程的初始状态都为就绪状态。3、每次运行所设计的处理器调度程序调度进程之前,为每个进程任意确定它的要求运行时间。4、此程序是模拟处理器调度,因此,被选中的进程并不实际启动运行,而是执行已运行时间+1来模拟进程的一次运行,表示进程已经运行过一个单位时间。.5、在所设计的程序中应有显示或打印语句,能显示或打印每次被选中的进程名以及运行一次后进程队列的变化。6、为进程任意确定要求运行时间,运行所设计的处理器调度程序,显示或打印逐次被选中进程的进程名以及进程控制块的动态变化过程。7、设有一个就绪队列,就绪进程按优先数(优先数范围0-100)由小到大排列(优先数越小,级别越高)。当某一进程运行完一个时间片后,其优先级应下调(如优先数加2或3)。8、例如一组进程如下表:进程名ABCDEFGHJKLM到达时间012368121212182525服务时间641051251043158三、实验报告1、程序中使用的数据结构及符号说明。2、给出主要算法的流程图3、给出程序清单并附上注释4、打印程序运行时的初值和运行结果。(运行一个进程输出一次结果)三、实验代码#include<stdio.h>#include<stdlib.h>#include<conio.h>#definegetpch(type)(type*)malloc(sizeof(type))//为进程创建一个空间structworktime{floatTb;//作业运行时刻floatTc;//作业完成时刻floatTi;//周转时间floatWi;//带权周转时间};structjcb{charname[10];//作业名floatsubtime;//作业到达时间floatruntime;//作业所需的运行时间charresource;//所需资源floatRp;//后备作业响应比charstate;//作业状态}printf("\n");}intjudge(JCB*p)//判断所有进程运行结束{intflag=1,i;for(i=0;i<N;i++){if(p->state!='e'){flag=0;break;}p=p->link;}returnflag;}voidRRget()//时间片轮转算法{JCB*s;intflag1=0;s=(JCB*)malloc(sizeof(JCB));s=front;printf("\n--------------------------------------------\n");output();printf("请输入任意一键继续\n");getch();//按任意键继续s=front;while(flag1!=1){if(s->state=='r'){s->worked_time++;s->need_time--;if(s->need_time==0)s->state='e';output();printf("请输入任意一键继续...\n");getch();}if(s->state=='e'&&s->flag==0){printf("进程%s已经运行完成!\n\n",s->name);s->flag=1;}s=s->link;flag1=judge(s);}printf("--------------------------------------------\n");}voidinput(){inti,num;printf("\n请输入作业的个数:");scanf("%d",&num);for(i=0;i<num;i++){printf("\n作业号No.%d:\n",i);p=getpch(JCB);printf("\n输入作业名:");scanf("%s",p->name);printf("\n输入作业到达时刻:");scanf("%f",&p->subtime);printf("\n输入作业运行时间:");scanf("%f",&p->runtime);printf("\n");p->state='w';p->link=NULL;sort();}}intspace(){intl=0;JCB*jr=ready;while(jr!=NULL){l++;jr=jr->link;}return(l);}voiddisp(JCB*jr,intselect){if(select==3)printf("\n作业到达时间服务时间响应比运行时刻完成时刻周转时间带权周转时间\n");elseprintf("\n作业到达时间服务时间运行时刻完成时刻周转时间带权周转时间\n");printf("|%s\t",jr->name);printf("|%.2f\t",jr->subtime);printf("|%.2f\t",jr->runtime);if(select==3&&p==jr)printf("|%.2f",jr->Rp);if(p==jr){printf("|%.2f\t",jr->wt.Tb);printf("|%.2f",jr->wt.Tc);printf("|%.2f\t",jr->wt.Ti);printf("|%.2f",jr->wt.Wi);}printf("\n");}intdestroy(){printf("\n作业[%s]已完成.\n",p->name);free(p);return(1);}voidcheck(intselect){JCB*jr;printf("\n****当前正在运行的作业是:%s",p->name);disp(p,select);jr=ready;printf("\n****当前就绪队列状态为:\n");while(jr!=NULL){jr->Rp=(jr->runtime+T-jr->subtime)/jr->runtime;disp(jr,select);jr=jr->link;}destroy();}voidrunning(JCB*jr){if(T>=jr->subtime)jr->wt.Tb=T;elsejr->wt.Tb=jr->subtime;jr->wt.Tc=jr->wt.Tb+jr->runtime;jr->wt.Ti=jr->wt.Tc-jr->subtime;jr->wt.Wi=jr->wt.Ti/jr->runtime;T=jr->wt.Tc;}intmain(){intselect=0,len,h=0;floatsumTi=0,sumWi=0;printf("\t---*****************---\n");printf("请选择作业调度算法的方式:\n");printf("\t1.FCFS2.SJF3.HRN4.RR\n\n");printf("\t---*****************---\n");printf("请输入作业调度算法序号(1-4):");scanf("%d",&select);if(select==4){creatJCB();RRget();}else{input();len=space();while((len!=0)&&(ready!=NULL)){h++;printf("\n执行第%d个作业\n",h);p=ready;ready=p->link;p->link=NULL;p->state='R';running(p);sumTi+=p->wt.Ti;sumWi+=p->wt.Wi;check(select);if(select==2&&h<len-1)SJFget();if(s

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论