操作系统实验一处理及调度

实验1   处理器调度  实验报告

一、实验内容

按优先数调度算法实现处理器调度。

二、实验目的

在采用多道程序设计的系统中,往往有若干个进程同时处于就绪状态。当就绪进程个数大于处理器数时,就必须依照某种策略来决定哪些进程优先占用处理器。本实验模拟在单处理器情况下的处理器调度,帮助学生加深了解处理器调度的工作。

三、实验原理

设计一个按优先数调度算法实现处理器调度的程序。

 (1) 假定系统有五个进程,每一个进程用一个进程控制块PCB来代表,进程控制块的格式为:

进程名

指针

要求运行时间

优先数

状态

其中,进程名——作为进程的标识,假设五个进程的进程名分别为P1,P2,P3,P4,P5。

指针——按优先数的大小把五个进程连成队列,用指针指出下一个进程的进程控制块的首地址,最后一个进程中的指针为“0”。

要求运行时间——假设进程需要运行的单位时间数。

优先数——赋予进程的优先数,调度时总是选取优先数大的进程先执行。

状态——可假设有两种状态,“就绪”状态和“结束”状态。五个进程的初始状态都为“就绪”,用“R”表示,当一个进程运行结束后,它的状态为“结束”,用“E”表示。

(2) 在每次运行你所设计的处理器调度程序之前,为每个进程任意确定它的“优先数”和“要求运行时间”。

(3) 为了调度方便,把五个进程按给定的优先数从大到小连成队列。用一单元指出队首进程,用指针指出队列的连接情况。例:

  队首标志

         K2    

K1

P1

 K2

P2

 K3

P3

 K4

P4

 K5

P5

 

0

 

K4

 

K5

 

K3

 

K1

 

2

 

3

 

1

 

2

 

4

 

1

 

5

 

3

 

4

 

2

 

R

 

R

 

R

 

R

 

R

 

PCB1

 

PCB2

 

PCB3

 

PCB4

 

PCB5

 

(4) 处理器调度总是选队首进程运行。采用动态改变优先数的办法,进程每运行一次优先数就减“1”。由于本实验是模拟处理器调度,所以,对被选中的进程并不实际的启动运行,而是执行:

优先数-1

要求运行时间-1

来模拟进程的一次运行。

提醒注意的是:在实际的系统中,当一个进程被选中运行时,必须恢复进程的现场,让它占有处理器运行,直到出现等待事件或运行结束。在这里省去了这些工作。

(5) 进程运行一次后,若要求运行时间¹0,则再将它加入队列(按优先数大小插入,且置队首标志);若要求运行时间=0,则把它的状态修改成“结束”(E),且退出队列。

(6) 若“就绪”状态的进程队列不为空,则重复上面(4)和(5)的步骤,直到所有进程都成为“结束”状态。

(7) 在所设计的程序中应有显示或打印语句,能显示或打印每次被选中进程的进程名以及运行一次后进程队列的变化。

(8) 为五个进程任意确定一组“优先数”和“要求运行时间”,启动所设计的处理器调度程序,显示或打印逐次被选中进程的进程名以及进程控制块的动态变化过程。

源程序及注释

程序中使用的数据结构及符号说明。

程序中使用的数据结构是

数据结构

struct PCB{//定义数据结构

int name;

int worktime;

int priority;

char condition;

struct PCB * next;

};

“********”是区分每一次执行之后的区域

“########”是区分执行完的进程的区域

注:C语言的代码中实参与形参可能用的字母是一个,请加以注意区分

C语言代码如下:

#include<stdio.h>

#include<stdlib.h>

#include<time.h>

struct PCB{//定义数据结构

int name;

int worktime;

int priority;

char condition;

struct PCB * next;

};

Sort(PCB *L,PCB *Q){//对于输入的节点进行排序(找到合适的位置)并且插入

if(!(L->next)){//如果链表为空直接头插法插入节点

Q->next=L->next;

L->next=Q;

}

else if(Q->priority>=(L->next)->priority){//如果优先级的大于L之后的那个节点, 直接插L后边

Q->next=L->next;

L->next=Q;

}

else{//否则一直往后插

L=L->next;

if(!(L->next)){

Q->next=L->next;

L->next=Q;

}

else{

Sort(L,Q);

}

}

}

InitPCB(PCB *L){//初始化,并且对所产生的节点进行复制赋值

PCB *p,*Q;

srand((unsigned int)time(0));//以时间为种子,保证每次随机数不一样

for(int i=1;i<=5;i++)

{

p=(PCB*)malloc(sizeof(PCB));//16-25行是产生一个节点

p->name=i;

p->next=NULL;

p->worktime=rand()%5;

while(p->worktime==0)

p->worktime=rand()%5;//如果工作时间为0,则继续取随机数,直到不为0

p->priority=rand()%5;

p->condition ='R';

Sort(L,p);

}

}

Printf(PCB *L){//输出执行一次之后的情况

printf("首进程:\t");

printf("%d\n",L->next->name);

printf("\n");

while(L->next){

printf("进程名\t");

printf("    剩余工作时间\t");

printf("优先数\t");

printf("状态\n");

printf("  %d\t",(L->next)->name);

printf("\t%d\t",(L->next)->worktime);

printf("\t  %d\t",(L->next)->priority);

printf(" %c\n",(L->next)->condition);

L=L->next;

}

}

Run(PCB *T){//对首进程执行一次

if(T->next){

T->next->worktime-=1;

T->next->priority-=1;

Printf(T);

printf("*******************************************\n");

if(T->next->worktime==0){

T->next->condition='E';

printf("已结束的进程:\n");

printf("进程名\t");

printf("    剩余工作时间\t");

printf("优先数\t");

printf("状态\n");

printf("  %d\t",(T->next)->name);

printf("\t%d\t",(T->next)->worktime);

printf("\t  %d\t",(T->next)->priority);

printf(" %c\n",(T->next)->condition);

printf("############################################\n");

T->next=T->next->next;

}

}

}

int main(){

int i;

PCB *L,*M;

L=NULL;

L=(PCB*)malloc(sizeof(PCB));

L->next=NULL;

M=NULL;

M=(PCB*)malloc(sizeof(PCB));

M->next=NULL;

InitPCB(L);

printf("最初的情况是:\n");

printf("\n");

Printf(L);//打印最初的情况

printf("*******************************************\n");

for(i=1;;i++){

if(!(L->next)&&(L->worktime)!=0){

printf("结束");

break;

}

if(L->next){

printf("执行%d次之后的情况:\n",i);

Run(L);

M=L->next;

L->next=L->next->next;

Sort(L,M);

}

}

}

(单纯是自己写着玩,欢迎改正!!)

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现了如下四种调度算法的模拟: (1)时间片轮转调度 (2)优先数调度 (3)最短进程优先 (4)最短剩余时间优先 模拟过程使用了JProgressBar作为进程状态条,更为直观地观察到每个进程的执行状态。 程序用户说明: 1、在上图标号1处输入要创建随机进程的个数,仅可输入正数,非正数会有相关提示。然后点击标号2处的“创建进程”按钮,随进创建的进程显示在程序界面的中央窗口,如标号3所示。 2、创建好随机进程后,在标号4的单选框选择将要模拟执行的调度算法,然后点击标号5处的“开始模拟”,程序开始执行。标号3的列表会显示相应的调度变化。 3、模拟过程中,可以继续添加新的进程,操作同上。 4、 一个算法模拟执行完毕之后,可以点击标号6的“复位”按钮,可以重置列表的内容为程序模拟运行前的内容。复位成功后,可以继续选择其他调度算法进行模拟。 5、标号7显示为程序模拟过程中的时间,从1秒开始累计。 6、点击标号8的“清空”按钮,可以清空类别的进程,以便程序的下次执行。 题目要求: 题目四 单处理系统进程调度 一 、 课 程 设 计 目 的 1. 加深对进程概念的理解, 明确进程和程序的区别。 2. 深入了解系统如何组织进程、 创建进程。 3. 进一步 认识如何实现处理调度。 二 、 课 程 设 计 内 容 编写程序完成单处理系统中的进程调度, 要求实现时间片轮转、 优先数、 最短进程优 先和最短剩余时间优先四种调度算法实验具体包括: 首先确定进程控制块的内容, 进程控 制块的组成方式; 然后完成进程创建原语和进程调度原语; 最后编写主函数对所作工作进行 测试。 模拟程序只对你所设置的“ 虚拟 PCB” 进行相应的调度模拟操作, 即每发生“ 调度” 时, 显示出当前运行进程的“ 进程标识符”、“ 优先数”、“ 剩余运行时间” 等, 而不需要对系 统中真正的 PCB 等数据进行修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值