39 进程调度实验

一、 实验目的

1.用高级语言完成一个进程调度程序,以加深对进程的概念及进程调度算法的理解。

2.实验要求

3.设计一个有 N(N不小于5)个进程并发执行的进程调度模拟程序。

4.进程调度算法:“时间片轮转法”调度算法对N个进程进行调度。

二、 实验内容和要求

完成两个算法(简单时间片轮转法、多级反馈队列调度算法)的设计、编码和调试工作,完成实验报告。

1) 每个进程有一个进程控制块(PCB)表示。进程控制块包含如下信息:进程名、优先级、到达时间、需要运行时间、已用CPU时间、进程状态等等。

2) 每个进程的状态可以是就绪 r(ready)、运行R(Running)、或完成F(Finished)三种状态之一。

3) 就绪进程获得 CPU后都只能运行一个时间片。用已占用CPU时间加1来表示。

4) 如果运行一个时间片后,进程的已占用 CPU时间已达到所需要的运行时间,则撤消该进程,如果运行一个时间片后进程的已占用CPU时间还未达所需要的运行时间,也就是进程还需要继续运行,应把它插入就绪队列等待下一次调度。

5) 每进行一次调度,程序都打印一次运行进程、就绪队列中各个进程的 PCB,以便进行检查。   

6) 重复以上过程,直到所要进程都完成为止。

三、 实验方法、步骤及结果测试

1.源程序名:1125.c

可执行程序名:1125.exe

2.原理分析及流程图

1)理解简单轮转法与多级反馈队列调度算法;

2)流程图:

3.主要程序段及其解释:

#include<stdio.h>

#define MAX 24

typedef struct node
{
    char name[10];//作业名
    int arrivetime;//作业到达时间
    int runtime;//作业所需的运行时间
    int usetime; //已用CPU时间
    char stage; //进程的状态
    int starttime; //开始时间
    int endtime; //结束时间
    int zztime; //作业周转时间
    float zzxs; //周转系数
}JCB;

static unsigned int N=5;  //作业数
static int current=0, current1=0;  //当前时间
static unsigned int j=-1, j1=-1;
JCB job[MAX];

void Line();
void FCFS();
void getValue();
void getValue1();
void input();
void print();
void choice();
void SJF();

void getValue()
{
    unsigned int i;
    current=job[0].arrivetime;
    for(i=0; i<N; i++)   
    {
        if(job[i].stage==‘r‘ && current>=job[i].arrivetime)
        {
            if(job[i].usetime==0)
                job[i].starttime=current;
            job[i].stage=‘R‘;   //程序正在运行
            job[i].usetime++;  //CPU的运行时间加1
            current++;
        }
        if(job[i].usetime==job[i].runtime && job[i].stage==‘R‘)
        {
            j++;          //用来标记有多少进程完成了
            job[i].stage=‘F‘;
            job[i].endtime=current;
            job[i].zztime=job[i].endtime-job[i].arrivetime;
            job[i].zzxs=(float)job[i].zztime/(float)job[i].runtime;
        }
        if(job[i].stage!=‘F‘)
            job[i].stage=‘r‘;  //运行完之后变回就绪态
        if(i==N-1)   //进入死循环了
            i=-1;
        if(j==N-1)
            break;
    }
}

void getValue1()
{
    unsigned int i=0, h, rest;
    current1=job[0].arrivetime;
    for(; i<N; i++)   
    {
        if(job[i].stage==‘2‘)
        {
            h=0;
            while(h<N)     //判断当前时刻的这一级是否有进程
            {
                if(job[h].stage==‘r‘ && current1>=job[h].arrivetime)
                {    
                    i=h;
                    h=N;
                }
                h++;
            }
        }
        else if(job[i].stage==‘3‘)
        {
            h=0;
            while(h<N)     //判断当前时刻的这一级是否有进程
            {
                if(job[h].stage==‘2‘)
                {    
                    i=h;
                    h=N;
                }
                h++;
            }
        }
        if(job[i].stage==‘r‘ && current1>=job[i].arrivetime)      
        {
            if(job[i].usetime==0)
                job[i].starttime=current1;
            job[i].stage=‘R‘;   //程序正在运行
            job[i].usetime++;  //CPU的运行时间加1
            current1++;
            if(job[i].usetime==job[i].runtime)
            {
                j1++;
                job[i].stage=‘F‘;
                job[i].endtime=current1;
                job[i].zztime=job[i].endtime-job[i].arrivetime;
                job[i].zzxs=(float)job[i].zztime/(float)job[i].runtime;
            }
            else    //还没完成则进入下一级
                job[i].stage=‘2‘;
        }
        else if(job[i].stage==‘2‘)
        {
            job[i].stage=‘R‘;
            job[i].usetime+=2;
            current1+=2;
            if(job[i].usetime>=job[i].runtime)
            {
                j1++;
                job[i].stage=‘F‘;
                rest=job[i].usetime-job[i].runtime;
                current1=current1-rest;
                job[i].endtime=current1;
                job[i].zztime=job[i].endtime-job[i].arrivetime;
                job[i].zzxs=(float)job[i].zztime/(float)job[i].runtime;
            }
            else    //还没完成则进入下一级
                job[i].stage=‘3‘;
        }
        else if(job[i].stage==‘3‘)
        {
            job[i].stage=‘R‘;
            job[i].usetime+=4;
            current1+=4;
            if(job[i].usetime>=job[i].runtime)
            {
                j1++;
                job[i].stage=‘F‘;
                rest=job[i].usetime-job[i].runtime;
                current1=current1-rest;
                job[i].endtime=current1;
                job[i].zztime=job[i].endtime-job[i].arrivetime;
                job[i].zzxs=(float)job[i].zztime/(float)job[i].runtime;
            }
            else    //还没完成则在最后一级继续轮转
                job[i].stage=‘3‘;
        }
        if(i==N-1)   //进入死循环了
            i=-1;
        if(j1==N-1)
            break;
    }
}

void input()
{
    int i, jobNum, choi;
    printf("1.自选作业个数\n");
    printf("2.系统默认作业个数\n");
    printf("你的选择是:");
    scanf("%d", &choi);
    switch(choi)
    {
    case 1:
        {
            do{
                printf("\nEnter process number(作业个数应在2~24之间):");
                scanf("%d", &jobNum);   //输入作业数
                N=jobNum;
                printf("\n");
            }while(N<2 || N>24);
            break;
        }    
    case 2:
        printf("\n系统默认作业个数为5");
        break;
    }
    for(i=0; i<jobNum; i++)
    {
        printf("\njob %d name:",i+1);
        scanf(" ");
        gets(job[i].name);    //输入作业名
        printf("arrive time:");
        scanf(" %d",&job[i].arrivetime);    //输入作业达到时间
        printf("running time:");
        scanf(" %d",&job[i].runtime);    //输入作业执行时间
    }
}

void print()
{
    unsigned int i;
    printf("     name  arrivetime  runtime  starttime  endtime  zztime  zzxs\n");    
    for(i=0; i<N; i++)
    {
        printf("jod%d",i+1);
        printf("  %s\t\t%d         %d         %d         %d        %d     %.2f\n",job[i].name,job[i].arrivetime,job[i].runtime,job[i].starttime,job[i].endtime,job[i].zztime,job[i].zzxs);
    }
}
void choice()
{
    int mark;
    do{
        printf("\n\n1. 简单轮转法;\n2. 多级反馈队列调度算法;\n3. 退出.");
        printf("\nMake choice: ");
        scanf("%d", &mark);
        switch(mark)
        {
            case 1:
                FCFS();     //先来先服务
                break;
            case 2:   
                SJF();     //短作业优先
                break;    
            case 4:
                return;
            default:
                printf("\nerror!");
        }
    }while(mark!=4);
}

void Line()
{
    unsigned int a, b;
    JCB mark;
    current=0; current1=0;
    j=-1; j1=-1;
    for(a=0; a<N; a++)
    {    
        job[a].usetime=0;
        job[a].stage=‘r‘;    //就绪态
        job[a].starttime=0;
        job[a].endtime=0;
        job[a].zztime=0;
        job[a].zzxs=0;
    }
    for(a=0;a<N-1; a++)  //通过到达时间整体排序
    {
        for(b=a+1; b<N; b++)
        {
            if(job[b].arrivetime<job[a].arrivetime)
            {
                mark=job[b];
                job[b]=job[a];
                job[a]=mark;    
            }
        }
    }
}

void FCFS()
{
    Line();
    getValue();  //给每个作业内的相关参数赋值
    print();  //打印出来
}

void SJF()
{
    Line();
    getValue1();
    print();  //打印出来
}

void main()
{
    input();     //输入
    print();     //打印输出
    choice();    //选择方式
}

4.运行结果及分析

图4.1 提示用户输入信息

图4.2 简单轮转法结果

图4.3 多级反馈队列调度算法结果

四、 实验总结

在前一次作业调度程序的基础上,改进成进程调度其实并不难,因为有那样的思维在里面,但是在做这次实验的过程中,首先理解简单轮转法和多级反馈跳读算法是很关键的,理解后顺着算法的思路编程,即使出现问题了,也能很快的找到是哪里的问题,并且不断地调试、改正,最后得到结果。

时间: 2024-11-07 15:35:42

39 进程调度实验的相关文章

1202实验三 进程调度实验

一.实验目的 用高级语言完成一个进程调度程序,以加深对进程的概念及进程调度算法的理解. 二.实验内容和要求 1.要求:设计一个有 N(N不小于5)个进程并发执行的进程调度模拟程序. 进程调度算法:“时间片轮转法”调度算法对N个进程进行调度. 2.完成两个算法(简单时间片轮转法.多级反馈队列调度算法)的设计.编码和调试工作,完成实验报告. 1) 每个进程有一个进程控制块(PCB)表示.进程控制块包含如下信息:进程名.优先级.到达时间.需要运行时间.已用CPU时间.进程状态等等. 2) 每个进程的状

实验三进程调度实验

1. 目的和要求 实验目的 用高级语言完成一个进程调度程序,以加深对进程的概念及进程调度算法的理解. 实验要求 设计一个有 N(N不小于5)个进程并发执行的进程调度模拟程序. 进程调度算法:“时间片轮转法”调度算法对N个进程进行调度. 2. 实验内容 完成两个算法(简单时间片轮转法.多级反馈队列调度算法)的设计.编码和调试工作,完成实验报告. 1) 每个进程有一个进程控制块(PCB)表示.进程控制块包含如下信息:进程名.优先级.到达时间.需要运行时间.已用CPU时间.进程状态等等. 2) 每个进

0512 操作系统进程调度实验

 班级:14商业软件1工程2班  姓名:朱杰  学号:201406114232  1.    目的和要求 1.1.           实验目的 用高级语言完成一个进程调度程序,以加深对进程的概念及进程调度算法的理解. 1.2.           实验要求 1.2.1例题:设计一个有 N个进程并发执行的进程调度模拟程序. 进程调度算法:采用最高优先级优先的调度算法(即把处理机分配给优先级最高的进程)和先来先服务(若优先级相同)算法. (1).  每个进程有一个进程控制块(PCB)表示.进程控制

39 作业调度实验

一. 实验目的 (1)加深对作业调度算法的理解: (2)进行程序设计的训练. 二. 实验内容和要求 用高级语言编写一个或多个作业调度的模拟程序. 单道批处理系统的作业调度程序.作业一投入运行,它就占有计算机的一切资源直到作业完成为止,因此调度作业时不必考虑它所需要的资源是否得到满足,它所运行的时间等因素. 作业调度算法: 1) 采用先来先服务(FCFS)调度算法,即按作业到达的先后次序进行调度.总是首先调度在系统中等待时间最长的作业. 2) 短作业优先 (SJF) 调度算法,优先调度要求运行时间

12.03进程调度实验点评

23李名贵,http://www.cnblogs.com/llmg/p/5016932.html 评论:进程状态可以设置多一个finish状态,在结束一个进程后,提示进程已完成,程序展示效果更好. 24施振成 评论:没有完成 25黄楠 评论:没有完成 26谢秋有 http://www.cnblogs.com/xieqiuyou/p/5017244.html 评论:运行结果直接明了,时间轮转法体现了公平性 28王鸾 评论:没有完成

原创 单片机实验

原创说明:此随笔为单片机(AT89C51.AT89C52)实验 前三个实验类型为汇编编程,难度较大,重在思路和细节的把握. 后四个实验为动手较强的单片机实验,编程相对简单. 考查点: 1.对单片机汇编基本编程把握 2.单片机的中断,包括外部中断.定时计数.串口通信 3.对单片机的结构.工作原理,各个端口的特点使用把握 4.会使用proteus仿真软件的使用,以及与keil的联调使用 单片机实验(一) 一.实验题目: 试编写一段程序,其功能为将21H单元的内容8位分别依次存放到从22H开始的8单元

关于算法--蛮力法--最近对和凸包问题

一.最近对问题:即从一个二维或多位的空间中找出距离最近的两个点 1.步骤 a.分别计算每一对点之间的距离 b.找出距离最近的那一对 (为了避免重复计算,只考虑i<j的那些对) 2.JavaScript实现 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>最近对问题</title>

linux下nsf服务搭建

实验环境 RHEL5.9两台 实验一: 将/root 共享给192.168.10.20,可写.同步,允许客户机以root权限访问 服务端配置: [[email protected] ~]# rpm -qa |grep nfs  //检查软件包是否安装 nfs-utils-lib-1.0.8-7.9.el5 nfs-utils-1.0.9-66.el5 [[email protected] ~]# rpm -qa |grep portmap portmap-4.0-65.2.2.1 [[email

带权随机数问题--根据权重随机选择一条路径

最近工作中遇到了一个根据权重随机选择一条路径的问题,一时没有啥好方案,参考借鉴了网上的经验,得出了如下解决方案: 思路:1.求权重的和,对(0,权重之歌和]区间进行划分,每个权重占用长度为权重的区间: 2.产生一个在(0,权重之和]区间的等概率随机数: 3.该随机数落在哪个区间,则该区间对应的权重的映射为本次产生的带权随机数. 1 import java.util.ArrayList; 2 import java.util.HashMap; 3 import java.util.List; 4