- 154
- 1
- 约 14页
- 2017-08-18 发布于重庆
- 举报
优先数和轮转法进程调度实验报告
实验二 进程调度报告
基本信息
实验题目:进程调度
完成人:****
报告日期:###########
实验内容简要描述
1、实验目标:进程调度是处理机管理的核心内容。本实验要求用C语言编写和调试一个简单的进程调度程序。通过本实验可以加深理解有关进程控制块、进程队列的概念,并体会和了解优先数和时间片轮转调度算法的具体实施办法。
实验要求:
(1)设计进程进程控制块PCB表结构,分别适用于优先数调度算法和循环轮转调度算法。PCB结构通常包括以下信息:进程名,进程优先数(或轮转时间片),进程所占用的CPU时间,进程的状态,当前队列指针等。根据调度算法的不同,PCB结构的内容可以作适当的增删。
(2)建立进程就绪队列。对两种不同算法编制入链子程序。
(3)编制两种进程调度算法:1)优先数调度;2)循环轮转调度。
报告主要内容
设计思路:
设计就绪、执行、完成三个队列;根据输入进程的时间,按照需要的时间越多,优先级越低,(60减去所需时间)建立就绪队列。
对优先数调度算法实现,首先从就绪队列中取出第一个进程。进程执行,优先数减3,CPU时间片数加1,进程还需要时间片数减1,在此设置计数器count,来判断进程是否执行完成。若进程完成,标志flag为0,并插入完成队列;否则插入就绪队列,等待下一次继续执行。重复上述操作,直到进程全部完成。
对轮转法调度算法实现,从就绪队列取进程,在时间片数为2的时间内进程执行,计数器count加2,若进程完成,继续取下一个进程执行,否则,若时间片用完,计数器清零,将该进程排列到就绪队列的尾上。然后取下一个进程,由于计数器已经清零,故相当于又给了一个时间片。重复上述操作,直到进程全部完成。
主要数据结构:
(1)PCB结构:
typedef struct node
{
char name[20]; /*进程的名字*/
int prio; /*进程的优先级*/
int round; /*分配CPU的时间片*/
int cputime; /*CPU执行时间*/
int needtime; /*进程执行所需要的时间*/
char state; /*进程的状态,W--就绪态,R--执行态,F--完成态*/
int count; /*记录执行的次数*/
struct node *next; /*链表指针*/
}PCB;
(2)三个应用队列:
PCB *ready=NULL,*run=NULL,*finish=NULL; /*定义三个队列:就绪、执行和完成队列*/
主要代码结构:
(1)函数声明部分:
void GetFirst(); /*从就绪队列取得第一个节点*/
void Output(); /*输出队列信息*/
void InsertPrio(PCB *in); /*创建优先级队列,规定优先数越小,优先级越高*/
void InsertTime(PCB *in); /*时间片队列*/
void InsertFinish(PCB *in); /*时间片队列*/
void PrioCreate(); /*优先级输入函数*/
void TimeCreate(); /*时间片输入函数*/
void Priority(); /*按照优先级调度*/
void RoundRun(); /*时间片轮转调度*/
主函数:
int main()
{
char choise;
printf(请输入要创建的进程数目:\n);
scanf(%d,num);
getchar();
printf(输入进程的调度方法:(P/R)\n);
scanf(%c,choise);
switch(choise)
{
case P:
PrioCreate();
Priority();
break;
case R:
TimeCreate();
RoundRun();
break;
default:break;
}
Output();
}
主要代码段分析:
void Priority() /*按照优先级调度算法*/
{
int
您可能关注的文档
- VF设计公交车IC卡管理系统.doc
- Visual Source Safe 60安装技术文档.doc
- VisualC制作一个Sniffer实例.doc
- VisualCdoc潘杰.doc
- VisualC绘图.doc
- Virtex-II系列FPGA资料.doc
- VisualSourceSafe2005团队开发环境搭建.doc
- VC编程心得.doc
- VC随笔图形设备接口.doc
- VMware技术销售专家(VTSP)3.docx
- (2026春新版)部编版八年级语文下册《第一单元》PPT课件.pptx
- 2018电力监控系统网络安全监测装置技术规范.docx
- 2022电力监控系统安全防护方案审核要点.docx
- 2014电力电缆光伏系统EN 50618欧标.docx
- (2026春新版)人教版二年级数学下册《第三单元 万以内数的认识》教案.docx
- (2026春新版)人教版二年级数学下册《第四单元 万以内的加法和减法》教案.docx
- (2026春新版)人教版二年级数学下册《综合与实践 时间在哪里》教案.docx
- (2026春新版)苏教版二年级数学下册《综合与实践 时间有多长》教案 .pdf
- (2026春新版)部编版三年级语文下册第3单元(教案).docx
- (2026春新版)部编版三年级语文下册第8单元(教案).docx
原创力文档

文档评论(0)