欢迎来到天天文库
浏览记录
ID:35463195
大小:108.00 KB
页数:10页
时间:2019-03-24
《进程管理和调度的算法》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、进程管理和调度的算法实现一、实验目的进程调度是处理机管理的核心内容。本设计要求用高级语言编写和调试一个简单的进程调度程序。通过本实验可以加深理解有关进程控制块、进程队列的概念,并体会和了解优先权调度算法和时间片轮转调度算法的具体实施办法。二、实验内容1.设计进程控制块PCB表结构,分别适用于优先权调度算法和时间片轮转调度算法。2.PCB结构包括以下信息:进程名、进程优先数(或轮转时间片),进程所占用的CPU时间,进程的状态,当前队列指针等。根据调度算法的不同,PCB结构的内容可以作适当的增删。3.建立进程就绪队列。对两种不同算法编制入链子程
2、序。4・编制两种进程调度算法:a)优先数调度;b)时间片轮转调度。允许用户在程序运行时选择使用某一种调度算法。三、编程工具:C、Java、VC或其它可视化语言平台任选四、具体设计要求及有关说明选用优先数算法和简单时间片轮转法对五个进程进行调度,每个进程可有三种状态:运行状态(RUN)、就绪状态(READY)和完成状态。并假定初始状态为就绪状态。PRIO/ROUND//PRIO表示进程优先数,ROUND诗小;CPUT1ME〃进程占用CPU时间;COUNT〃计数器;NEEDTTME/进程到完成还要的CPU吋间;STATE//进程的状态;NEXT
3、//链指针2.进程控制块链结构如图所示。1.NAME设计进程控制块PCB结构如下://进程标识符;RUN其RUN程指针;中-当前运行进READY——就绪队列头指针;TAIL就绪队列尾指针;FINISH——完成队列头指针。为了便于处理,程序中进程的运行时间以时间片为单位计算。各进程的优先数或轮转吋间片数以及进程需运行的吋间片数的初值均由用户给定。3.程序说明:a)在优先数算法中,进程每执行一次,优先数减3,CPU时间片数加1,进程还需要的时间片数减1。在轮转法中,采用固定时间片,时间片数为2,进程每执行一次,CPU时间片数加2,进程还需要的时
4、间片数减2,并排到就绪队列的尾上。b)程序结构说明如下:整个程序由CREATE,F1RST1N,1NSERT1,INSERT2,PRINT,PR1SCH和ROUNDSCH过程组成。其中:CREATE的功能是创建新的进程,即创立进程的PCB,并将此PCB链入到就绪队列中去。FIRSTIN的功能是将就绪队列中的第一个进程投入运行。1NSERT1的功能是把述未完成且优先数小于别的进程PCB按进程优先数的顺序插入到就绪队列中。INSERT2是轮转法使用的过程,将执行了一个单位时间片数(为2)且还未完成的进程的PCB插入到就绪队列的队尾。PRINT打
5、印每执行一次后的所有进程的状态,这里,就绪(等待)用代表。PRISCH按优先数算法调度进程。ROUNDSCH按时间片轮转法调度进程。0)主程序中定义了PCB的结构和其它变量NUMBER——进程数,ALGO为10个字符长的字符串,存放耍求输入的算法的名,输入“PRIORITY”表示调用优先数算法,输入“ROUNDROBIN”表示调用循环轮转法,要求用户在程序运行时输入其中的一个。实现代码:#include,,iostream/,#include〃string〃#include〃cstring〃#1ncludelomanipusingnamcs
6、paccstd;SdefineN50//函数声明voidCREATE();voidINSERT1(structPCB*,int);void1NSERT2(structPCB*);voidINSERT3(structPCB*);voidFIRSTINO;voidPRTSCHO;voidROUNDSCIK);voidPRINT();//定义进程PCBstructPCB{charNAME[N];intPR10;intROUND;intCPUTIME;intCOUNT;intNEEDTIME;charSTATE;structPCB*NEXT;};s
7、tructPCB*READY,*TAIL,*RUN,*FINISH;intnumber;stringALGO;//主函数intm3in(){stringname;intj=0;//初始化各队列READY二NULL;TAIL二NULL;RUN二NULL;FINISH二NULL;loop:cout〈〈〃******************************〃〈〈end1;cout«〃*进程管理与调度*/z«endl;cout〈〈〃*-PRIORITY(优先数法)*〃〈〈endl;cout〈〈〃*•ROUNDROBTN(轮转法)«8、;cout〈〈〃*•EXIT(退出)*〃〈〈cndl;cout〈〈〃******************************〃〈〈end1;cout<
8、;cout〈〈〃*•EXIT(退出)*〃〈〈cndl;cout〈〈〃******************************〃〈〈end1;cout<
此文档下载收益归作者所有