欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > DOCX文档下载  

    处理器调度实验报告.docx

    • 资源ID:845764       资源大小:34.77KB        全文页数:11页
    • 资源格式: DOCX        下载积分:5金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要5金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    处理器调度实验报告.docx

    处理器调度班级:10网工三班学生姓名:谢昊天学号:1215134046实验目的和要求:选择一个调度算法,实现处理器调度。在采用多道程序设计的系统中,往往有假设干个进程同时处于就绪状态。当就绪进程个数大于处理器数时,就必须依照某种策略来决定哪些进程优先占用处理器。本实验模拟在单处理器情况下的处理器调度,帮助学生加深了解处理器调度的工作。实验内容与分析设计:本实验有两个题,学生可选择其中的一题做实验。第一题:设计一个按优先数调度算法实现处理器调度的程序。提示:(1)假定系统有五个进程,每-个进程用一个进程控制块PCB来代表,进程控制块的格式为:进程名,指针,要求运行时间,优先数,状态(2)在每次运行你所设计的处理器调度程序之前,为每个进程任意确定它的"优先数"和“要求运行时间"。(3)为了调度方便,把五个进程按给定的优先数从大到小连成队列。用一单元指出队首进程,用指针指出队列的连接情况。(4)处理器调度总是选队首进程运行.采用动态改变优先数的方法,进程每运行一次优先数就减"1"。由于本实验是模拟处理器调度,所以,对被选中的进程并不实际的启动运行,而是执行:优先数一1要求运行时间-1来模拟进程的一次运行.提醒注意的是:在实际的系统中,当一个进程被选中运行时,必须恢复进程的现场,让它占有处理器运行,直到出现等待事件或运行结束。在这里省去了这些工作。(5)进程运行一次后,假设要求运行时间0,那么再将它参加队列(按优先数大小插入,且置队首标志):假设要求运行时间=0,那么把它的状态修改成"结束"(E),且退出队列。(6)假设"就绪"状态的进程队列不为空,那么重复上面(4)和(5)的步骤,直到所有进程都成为“结束"状态。(7)在所设计的程序中应有显示或打印语句,能显示或打印每次被选中进程的进程名以及运行一次后进程队列的变化。(8)为五个进程任意确定一组"优先数"和"要求运行时间",启动所设计的处理器调度程序,显示或打印逐次被选中进程的进程名以及进程控制块的动态变化过程。第二题:设计一个按时间片轮转法实现处理器调度的程序。提示:(1)假定系统有五个进程,每一个进程用-个进程控制块PCB来代表。进程控制块的格式为:进程名,指针,要求运行时间,己运行时间,状态(2)每次运行所设计的处理器调度程序前,为每个进程任意确定它的"要求运行时间"。(3)把五个进程按顺序排成循环队列,用指针指出队列连接情况。另用标志单元记录轮到运行的进程。(4)处理器调度总是选择标志单元指示的进程运行。(5)进程运行一次后,应把该进程的进程控制块中的指针值送到标志单元,以指示下一个轮到运行的进程。同时,应判断该进程的要求运行时间与己运行时间,假设该进程的要求运行时间己运行时间,那么表示它尚未执行结束,应待到下一轮时再运行。假设该进程的要求运行时间=已运行时间,那么表示它已经执行结束,应指导它的状态修改成"结束"(E)且退出队列。此时,应把该进程的进程控制块中的指针值送到前面一个进程的指针位置。(6)假设"就绪"状态的进程队列不为空,那么重复上面的(4)和(5)的步骤,直到所有的进程都成为"结束"状态。(7)在所设计的程序中应有显示或打印语句,能显示或打印每次选中进程的进程名以及运行一次后进程队列的变化。(8)为五个进程任意确定一组"要求运行时间",启动所设计的处理器调度程序,显示或打印逐次被选中的进程名以及进程控制块的动态变化过程。实验步骤与调试过程:1 .翻升vc,新建工程,并建基于控制台的文件2 .确定五个进程并在运行所设计的处理器调度程序前确定每个进程要求运行时间3 .把五个进程按顺序排成循环队列,用指针指出队列连接情况4 .需求分析:了解根本原理,确定程序的根本功能,查找相关资料,画出根本的数据流图;【先来先效劳流程图】(开始->初始化说有的JCB使JCB按作业提交的时刻的先后顺序排队时间量Tl=O->调度对首作业投入运行->计算并打印作业i的完成时间Tc周转时间Ti带权周转时间Wi->更改时间量T的值->等待队列空?->空(不空一>调度对首作业投入运行)->计算并打印这组作业的平均周转时间及带权平均周转时间->结束);【高优先权流程图】开始->初始化PCB,输入进程信息-各进程按优先数从高到低排列->就绪队列空?->(空->结束)不空->就绪队列进程投入运行->时间片到,运行进程已占用CPU时间+1->运行进程己占用CPU时间已到达所需的运行时间->(己到达->进程完成,撤销该进程)->未到达->是运行进程的优先数T把运行进程插入就绪队列->就绪队列空?->)【按时间片轮转调度】(系统初始化->启动计数器->读取DTMF编码、摘、挂机信号->Of用户编号->所有用户任务以调用?->(没有调用->根据用户编号,子程序号调用相应任务->指向下一用户,编号+1->所有用户任务以调用?->)已调用->发送DTMF编码->定时时间己到?->(没有到->定时时间己到?->)->己到->启动计数器)6 .在所设计的程序中应有显示或打印语句,能显示或打印每次选中进程的进程名以及运行一次后进程队列的变化7 .为五个进程任意确定组“要求运行时间",启动所设计的处理器调度程序,显示或打印逐次被选中的进程名以及进程控制块的动态变化过程。5.运行测试:实验结果:运行后可执行输入总进程个数后,显示出进程名,总运行时间,已运行时间,状态等信息,分别开始运行程序。运行完毕后会显示a进程己运行结束,进程被删除。完成处理器调度试验。四、疑难与小结:通过本次试验,我对处理器调度思想有了进-步的了解,通过动手实现其调度算法,更加深刻的理解了时间片轮调度算法与其他几种算法的不同优点。同时,在实验过程中,回忆书本上的理论知识,稳固了我的知识。1 轮转法就是按-定时间片(记为q)轮番运行各个进程。如果q是一个定值,那么轮转法是种对各进程时机均等的调度方法。2 .优先级调度的根本思想是,把肖前处于就绪队列中优先级最高的进程投入运行,而不管各进程的下一个CPU周期的长短和其他因素。3 .先来先效劳调度算法:高响应比优先实现进程调度.(用C语言实现),如果早就绪的进程排在就绪队列的前面,迟就绪的进程排在就绪队列的后面,那么先来先效劳(FCFS:firstcomefirstSerViCe)总是把当前处于就绪队列之首的那个进程调度到运行状态。4 .优先级调度程序:该程序由主程序、构造队列子程序、打印子程序、运行子程序构成。5.时间片轮转法程序:在此程序中由于程序比拟小,未进行分模块设计。直接采用单模块。五、主要算法和程序清单:按时间片轮转法:#includc<iostream>Sinclude<cstdlib>usingnamespacestd;typedefstructPNodestructPNode*next;charname10;intALL_Time;intRunedTime;charstate;*Proc;intProcNum;voidInitPCB(Proc&H)COUtG"请输入总进程个数:";cin>>ProcNum;intNum=ProcNum;H=(Proc)malIoc(sizeof(PNode);H->next=NULL;Procp=H;COIIt«"总进程个数为"<<ProcNum<<"个,请依次输入相应信nn"while(Num)p=p->next=(Proc)malIoc(sizeof(PNode);CoUt<e"进程名总运行时间已运行时间:";cin>>p'>name>>p->ALL-Time>>p->RunedTime;p->state='R'p->next=NULL;p->next=H->next;voidDispInfo(ProcH)Procp=H>next;doif(p->state!='E')CoUtX"进程名:*<<p'>name<<*t总运行时间:"p-ALL_Timo<<*t己运行时间:"p->Runod_Timc<<vt状态:*«p-StHte<<ndl;p=p->next;elsep=p->next;)while(p!=H->next);voidSJP_Simu1ator(Proc&H)cout<<endl<<STARTn"intfIag=ProcNum;intround=0;Procp=H>next;while(p->ALL_Time>p->RuncdTime)round+;cout<<endl<<*Round*<<round<<*正在运行"<<p->name<<"进程"<<endl;p->RuncdTime+;DispInfo(三);if(p->ALL_Time=p->RunedTime)p->state=,E'flag;COUt<Xp->namZU进程己运行结束,进程被删除!n"p=p->next;while(flag&&p->ALL_Time=p->RunedTime)p=p->next;cout<<endl<<*ENDn*;voidmain()ProcH;InitPCB(三);DispInfo(三);SJP-Simulator(三);system(*pause*);先来先效劳法:#include<stdio.h>floatt,d;/*定义两个全局变最*/struct/*定义一个结构体数组,包括进程的信息*/intid;floatArriveTime;floatRequestTime;floatStartTimc;floatEndTime;floatRunTime;floatDQRunTimc;intStatus;arrayTask4;/*定义初始化的结构体数组*/GotTaSko/*给结构体数组赋值,输入到达,效劳时间*/inti;floata;for(i=0;i<4;i+)arrayTaski.id=i+l;printf(*inputthenumber");printf(*inputthetheArriveTimeofarrayTask%d:*,i);*用户输入进程的时间,初始为零*/SCanf("%f",&a);arrayTaski.ArriveTime=a;printf(*inputtheRequestTimeofarrayTask%di);SCanf("%f",&a);arrayTaski.RequestTime=a;arrayTaski.StartTime=0;arrayTaski.EndTime=O;arrayTaski.RunTime=O;arrayTaski.Status=O;*开始默认的标志位零*/intfcfs()/*定义FCFS中寻找未执行的进程的最先到达时间*/inti,j,w=0;/*在结构体数组中找到一个未执行的进程*/for(i=0';i<4;i+)if(arrayTaski.Status=O)t=arrayTaski.ArriveTime;w=l;if(w=l)break;for(i=0;i4;i+)/*查找数组中到达时间最小未执行的进程*/if(arrayTaski.ArriveTimot&&arrayTaski.Status=O)t=arrayTaski.ArriveTime;/*返回最小到达时间的数组的卜标*/for(i=0;i<4;i+)if(arrayTaski.ArrivcTimc=t)returni;intsjf()/*定义FCFS中寻找未执行的进程的最先到达时间*/inti,x=0,a=0,b=0;/*判断是不是第一个执行的进程*/floatg;for(i=0;i<4;i+)if(arrayTaski.Status=I)g=arrayTaski.EndTimc;x=l;if(x=0)/*第一个执行的进程按FCFS*/t=arrayTaskO.ArriveTime;for(i=0;i<4;i+)if(arrayTaski.ArriveTime<t)t=arrayTaski.ArriveTime;a=i;returna;)elsefor(i=Q;i<4;i+)if(arrayTaski.EndTime>g)g=arrayTaski.EndTime;for(i=Q;i<4;i+)if(arrayTaski.StatUS=O&&arrayTaski.ArriVeTime<=g)t=arrayTaski.RequestTimc;a=i;b=l;/*判断有没有进程在前个进程完成前到达*/if(b!=0)/*有进程到达那么按SJF*/for(i=0;i4;i+)if(arrayTaski.StatUS=O&&arrayTaski.ArriVeTime<=g&&arrayTaski.RcquestTime<t)t=arrayTaski.RequestTimc;a=i;returna;else*否那么按FCFS*/for(i=0;i<4;i+)if(arrayTaski.StatusO)t=arrayTaski.ArriveTime;for(i=0;i<4;i+)if(arrayTaski.StatUS=O&&arrayTaski.ArrivcTimc<t)t=arrayTaski.ArriveTimc;a=;returna;new(ints)/*定义执行进程后相关数据的修改*/inti,g=O;for(i=0;i<4;i+)if(arrayTaski.Status=O)continue;elseg=l;break;if(g=O)/*当处理的是第一个未执行的进程时执行*/arrayTasks.StartTime=arrayTasks.ArriveTime;arrayTasks.EndTime=arrayTasks.ReqUCStTime+arrayTasks.ArriveTime;arrayTasks.RUnTime=arrayTasks.RequcstTimc;arrayTasks.Status=I;g=2;if(g=l)/*当处理的不是第一个未执行的进程时执行*/arrayTasks.Status=I;for(i=0;i<4;i+)if(arrayTaski.Status=I)d=arrayTaski.EndTimc;for(i=0;i4;i+)/*查找最后执行的进程的完成时间*/if(arrayTaski.EndTime>dfearrayTaski.Status=I)d=arrayTaski.EndTimc;if(arrayTasks.ArrivcTime<d)/*判断修改的进程的到达时间是否在前一个执行的进程的完成时间前面*/arrayTasks.StartTinle=d;CISearrayTask,s.StartTime=arrayTasks.ArriveTime;arrayTasks.EndTime=arrayTasks.StartTime+arrayTasks.RequestTime;arrayTasks.RunTime=arrayTasks.EndTime-a,rayTasks.ArriveTime;arrayTasks.DQRunTimo=arrayTasks.RunTime/arrayTasks.RequestTime;PrintresultCintj)*定义打印函数*/Printf("%dt",arrayTaskj.id);printf(*%5.2ft",arrayTaskj.Ai'riveTime);printf(飞5.2ft",arrayTaskj.RequestTime);printf(*%5.2ft",arrayTaskj.StartTime);printf(*%5.2ft*,arrayTaskj.EndTime);printf(*%5.2ft",arrayTaskj.RunTime);printf(*%5.2fn*,arrayTaskj.DQRunTimc);main()intib,k1a,c=0;intd4;cIrscr();printf(*tF.FCFSr);printf(*tS.SFJn");printf(*tQ.EXITn");for(i=0;i+)(if(c)break;printf(pleaseinputthenumbera:n*);SCanf("%d",fta);switch(a)caseQ:c=l;break;caseF:Printf("ploaseinputthediffercnt-ArriveTimeofarrayTasksn")GetTaskO;Printf("*theresultoffcfsn");turnoverprintf(*NumbertArrivetSorvertStarttFinishtTurnovetTakepowertimen*);for(b=0;b<4;b+)/*调用两个函数改变结构体数的值*/k=fcfs();db=k;new(k);for(b=0;b<4;b+)PrintreSUIt(db);/*调用打印函数打出结果*/continue;caseS:printf(*pleaseinputthedifferent-RequestTimcofarrayTasksn*);GetTaskO;Printf("*theresultofsjfn");printf(*NurabertArrivetRequesttStarttEndtRuntDQRuntimen*);for(b=0;b<4;b+)k=sjf();db=k;new(k);for(b=0;b<4;b+)Printresult(db);continue;default:printf(*thenumberError,pleaseinputanothernumber!n*);优先级调度方法:include<stdio.h>ttinclude"conio.h"typodefstructPCb*定义结构*/(charname5;structpcb*noxt;intneedtime;intpriority;charstate5;N0DE;NODE*createprocess(intn)*创立队列*/(NODE*head,*s,*t;inttime,i=0,j;charpname5;head=(NODE*)malloc(sizeof(NODE);Printf("pleaseinputprocessname:*);scanf("%s",pname);strcpy(hcad->namc,pname);printf(*pleaseinputneedtime:*);scanf("%d",&time);head>needtime=time;printf(*pleaseinputpriority:*);scanf(飞d&j);head>priority=j;strcpy(hcad->state,"ready");head->next=NULL;t=head;for(i=l;i<n;i+)s=(NODE*)malloc(sizeof(NODE);printfC*pleaseinputprocessname:");getchar();gets(pname);strcpy(s->name,pnamc);printfC*pleaseinputneedtime:");canf("%d",&time);s->needtime=time;printf(*pleaseinputpriority:*);SCanf("%d",&j);s>priority=j;strcpy(s>state,"ready");s->next=NULL;t->next=s;t=s;returnhead;pri_process(NODE*p)/*输出进程队列*/inti;NODE*q;q=p->next.;printfCnnamctncedtimetprioritytstaten*);whiIe(q!=NULL)printf(j*%5st%2dt%2dt%5sn",q->name,q->needtime,q->priority,q->state);q=q->next;NODE*ordor(NODEhead_sort)*对进程的优先级进行排序*/NODE*p,*s,*q,*head,*r,*t;int叫pr;charname5;head=headsort;p=head->next;r=P;t=;q=p->next;while(r!=NULL)while(q!=NULL)if(p->priority<q->priority)m=p->priority;p->priority=q->priority;q->priority=m;strcmp(name,p->name);strcmp(p->name,q->name);strcmp(q->name,name);pr=p>needtime;p->needtime=q->needtime;q->needtimc=pr;p=q;q=q->next;r=r->next;P=t;q=p->next;return(headsort);Inain()*主程序*/NODE*p=YULL,*head=NULL,*m=NULL,*z=NULL,*n=XULL;intj,time,x=0;charc,pname5;cIrscr();printf(x*pleaseinputprocessnumber!");scanf(",&x);p=create_process(x);head->next=p;pri_process(head);gotchar();while(x>0)order(head);m=head>next;strcpy(m->state,"run");if(m->priority>=2)m->priority;m->needtime;if(hcad->ncxt!=NULL)pri_process(head);if(m>needtime=0)head->next=m->next;printf(*%shasfinishedn*,m>name);free(m);x一;getcharO;textmode(C80);textbackground(0);textcolor(4);printf(*ovci'!*);getchar();

    注意事项

    本文(处理器调度实验报告.docx)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开