操作系统实验进程调度.doc

操作系统实验进程调度.doc

ID:55584257

大小:40.50 KB

页数:10页

时间:2020-05-19

操作系统实验进程调度.doc_第1页
操作系统实验进程调度.doc_第2页
操作系统实验进程调度.doc_第3页
操作系统实验进程调度.doc_第4页
操作系统实验进程调度.doc_第5页
资源描述:

《操作系统实验进程调度.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、实验二进程调度⒈实验内容进程调度模拟实验。⒉实验目的通过模拟进程调度算法,了解进程调度的过程并比较不同的调度算法的区别。⒊实验题目设计一段程序来模拟优先级调度算法和时间片轮转算法。要求可以指定进程的数量、各进程需要CPU的时间和各进程的优先级。⒋实验提示⑴进程调度算法是指处理机的分配策略。优先数调度算法是指对每个进程确定一个优先数,进程调度总是让具有最高优先数的进程先使用处理机。如果进程具有相同的优先数,再按先来先服务的次序分配处理机。在本实例中采用动态优先数算法。时间片轮转算法是指就绪进程按就绪的先后次序

2、排成队列,每次总是选择就绪队列中的第一个进程占用处理机,但规定只能使用一个“时间片”。⑵系统中的进程可以用进程控制块PCB来表示,PCB的结构定义如表5-8所示:表5-8PCB结构进程标识符charname进程占用CPU时间intcputime进程优先数intprio完成进程还需要的时间intneedtime链指针structpcb*next⑶在进程调度时进程会交替的出现在运行、就绪和完成三种状态。可以定义三个链表来存放三种状态的进程。当进程运行时就把进程放入到运行链表中;当进程处于就绪状态时就将进程放入到

3、就绪链表中;当进程运行完毕时就将进程放入到完成链表中。由于同一时刻运行的进程只能有一个,所以运行链表只能有一个结点。在实例程序中为了使程序更简洁忽略了进程的等待状态,仅运行了优先数调度算法,由于篇幅有限,仅显示部分结果,对于时间片轮转调度算法,请读者自行运行。⑷主要变量及函数说明如表5-9所示:表5-9主要变量及函数说明structpcb进程控制块结构RUN、READY、FINSH运行、就绪、完成对列voidPRINTLINK(intt)显示三个队列,t为运行的次数PCB*CPCBLINK()建立就绪队列v

4、oidJXDLPX()将队列按优先级排序voidYXS()优先数调度算法voidSJP()时间片轮转算法⒌实例代码//进程调度算法proc.c//运行环境Redhad9.0gcc4.0#include#includetypedefstructpcb//定义PCB结构{charname[20];/*进程标识符*/intcputime;/*进程占用CPU时间*/intprio;/*进程优先数*/intneedtime;/*进程到完成还需要的CPU时间*/structpcb*

5、next;/*链指针*/}PCB;PCB*RUN,*READY,*RTAIL,*FINSH,*FTAIL;voidPRINTLINK(intt)/*输出3个队列*/{PCB*p;printf("CPU运行次数:___%d___",t);printf("______________________");printf("进程名t运行状态t运行次数t还需要运行次数");if(RUN!=NULL){printf("%st运行t%dt%d",RUN->name,RUN->cputime,R

6、UN->needtime);}elseprintf("*运行状态为空");p=READY;if(p!=NULL){while(p!=NULL){printf("%st就绪t%dt%d",p->name,p->cputime,p->needtime);p=p->next;}}elseprintf("*就绪队列为空");p=FINSH;if(p!=NULL){while(p!=NULL){//printf("进程名字为:%s",p->name);printf("%st完成t%dt%d

7、",p->name,p->cputime,p->needtime);p=p->next;}}elseprintf("*完成队列为空");getchar();}PCB*CPCBLINK()/*建立就绪队列*/{printf("建立就绪队列");inti,n,nt,pr;PCB*p,*q,*head;n=0;while(1){printf("请输入进程的个数(有效范围1-100):");scanf("%d",&n);printf("");if(n>=1&&n<=100)break;elsep

8、rintf("输入有误。请重新输入!");getchar();}head=(structpcb*)malloc(sizeof(structpcb));printf("输入第1个进程的名称:");scanf("%s",head->name);while(1){printf("需要的运行时间:");scanf("%d",&nt);if(nt>0)break;else{printf("输入无效,重新输入!");

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。