好文档 - 专业文书写作范文服务资料分享网站

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法

天下 分享 时间: 加入收藏 我要投稿 点赞

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法

操作系统实验报告

实验一

先来先服务FCFS与短作业优先SJF进程调度算法

学号: 班级: 姓名:

【实验题目】:先来先服务FCFS与短作业优先SJF进程调度算法 【实验目的】

通过这次实验,加深对进程概念的理解,进一步掌握进程状态的转变、进程调度的策略及对系统性能的评价方法。 【实验内容】 问题描述:

设计程序模拟进程的先来先服务FCFS与短作业优先SJF调度过程。假设有n个进程分别在T1, … ,Tn时刻到达系统,它们需要的服务时间分别为S1, … ,Sn。分别采用先来先服务FCFS与短作业优先SJF进程调度算法进行调度,计算每个进程的完成时间,周转时间与带权周转时间,并且统计n个进程的平均周转时间与平均带权周转时间。 程序要求如下:

1)进程个数n;每个进程的到达时间T1, … ,Tn与服务时间S1, … ,Sn;选择算法1-FCFS,2-SJF。

2)要求采用先来先服务FCFS与短作业优先SJF分别调度进程运行,计算每个进程的周转时间,带权周转时间,并且计算所有进程的平均周转时间,带权平均周转

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法

时间;

3)输出:要求模拟整个调度过程,输出每个时刻的进程运行状态,如“时刻3:进程B开始运行”等等;

4)输出:要求输出计算出来的每个进程的周转时间,带权周转时间,所有进程的平均周转时间,带权平均周转时间。 实现提示:

用C++语言实现提示:

1)程序中进程调度时间变量描述如下:

static int MaxNum=100; int ArrivalTime[MaxNum];

int ServiceTime[MaxNum]; int FinishTime[MaxNum]; int WholeTime[MaxNum];

double WeightWholeTime[MaxNum]; double AverageWT_FCFS,AverageWT_SJF; double AverageWWT_FCFS,AverageWWT_SJF; 2)进程调度的实现过程如下: ? 变量初始化;

? 接收用户输入n,T1, … ,Tn,S1, … ,Sn;算法选择1-FCFS,2-SJF;

? 按照选择算法进行进程调度,计算进程的完成时间、周转时间与带权周转时间;

? 计算所有进程的平均周转时间与平均带权周转时间;

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法

?

按格式输出调度结果。

实验要求:

1)上机前认真复习FCFS与SJF进程调度调度算法,熟悉进程调度的执行过程; 2)上机时独立编程、调试程序;

3)根据具体实验要求,完成好实验报告(包括实验的目的、内容、要求、源程序、实例运行结果截图)。 【源程序】

头文件FCFS、h #include #define MaxNum 100 struct Process_struct{ int Number; //进程编号 char Name[MaxNum]; //进程名称 int ArrivalTime; //到达时间 int ServiceTime; //开始运行时间 int FinishTime; //运行结束时间 int WholeTime; //运行时间 int run_flag; //调度标志 int order; //运行次序 double WeightWholeTime; //周转时间 double AverageWT_FCFS,AverageWT_SJF; //平均周转时间

double AverageWWT_FCFS,AverageWWT_SJF; //平均带权周转时间 }Process[MaxNum];

int N; //实际进程个数 int FCFS(); //先来先服务

int FCFS(){ //先来先服务算法 int i; int temp_time=0; //当前时间 temp_time=Process[0]、ArrivalTime; for(i=0;i

temp_time=Process[i]、FinishTime; Process[i]、order=i+1; }return 0;

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法

}

头文件SJF、h #include

int SJF(); //短作业优先

int SJF(){ //短作业优先算法 int temp_time=0; //当期那时间 int i=0,j; int number_schedul,temp_counter; //进程编号,当前已执行进程个数 float run_time; run_time=Process[i]、WholeTime; j=1; while((j

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法

if((Process[j]、ArrivalTime<=temp_time)&&(!Process[j]、run_flag)) if(Process[j]、WholeTime

主程序Main、cpp #include #include \、h\#include \、h%using namespace std;

int Pinput(); //进程参数输入 int Poutput(); //调度结果输出 void main() { int option; Pinput(); printf(\请选择算法:\\n\ printf(\、先来先服务\\n\ printf(\、短作业优先\\n\ printf(\、退出\\n\ scanf(\ switch(option) { case 0: printf(\运行结束。\\n\ break; case 1: printf(\对进程用先来先服务调度。\\n\\n\ FCFS(); Poutput(); break;

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法

操作系统实验先来先服务FCFS和短作业优先SJF进程调度算法操作系统实验报告实验一先来先服务FCFS与短作业优先SJF进程调度算法学号:班级:姓名:【实验题目】:先来先服务FCFS与短作业优先SJF进程调度算法【实验目的】通过这次实验,加深对进程概念的理解,进一步掌握进程状态的转变、进程调
推荐度:
点击下载文档文档为doc格式
52sb00mecd7l7tx29ybm0wacw0f2i000g7a
领取福利

微信扫码领取福利

微信扫码分享