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

上传人:共*** 文档编号:88539966 上传时间:2019-04-30 格式:DOC 页数:12 大小:311KB
返回 下载 相关 举报
操作系统实验一报告先来先服务FCFS和短作业优先SJF进程调度算法_第1页
第1页 / 共12页
操作系统实验一报告先来先服务FCFS和短作业优先SJF进程调度算法_第2页
第2页 / 共12页
操作系统实验一报告先来先服务FCFS和短作业优先SJF进程调度算法_第3页
第3页 / 共12页
操作系统实验一报告先来先服务FCFS和短作业优先SJF进程调度算法_第4页
第4页 / 共12页
操作系统实验一报告先来先服务FCFS和短作业优先SJF进程调度算法_第5页
第5页 / 共12页
点击查看更多>>
资源描述

《操作系统实验一报告先来先服务FCFS和短作业优先SJF进程调度算法》由会员分享,可在线阅读,更多相关《操作系统实验一报告先来先服务FCFS和短作业优先SJF进程调度算法(12页珍藏版)》请在金锄头文库上搜索。

1、操作系统实验报告实验一先来先服务FCFS和短作业优先SJF进程调度算法学号:班级:姓名:【实验题目】:先来先服务FCFS和短作业优先SJF进程调度算法【实验目的】 通过这次实验,加深对进程概念的理解,进一步掌握进程状态的转变、进程调度的策略及对系统性能的评价方法。【实验内容】问题描述:设计程序模拟进程的先来先服务FCFS和短作业优先SJF调度过程。假设有n个进程分别在T1, ,Tn时刻到达系统,它们需要的服务时间分别为S1, ,Sn。分别采用先来先服务FCFS和短作业优先SJF进程调度算法进行调度,计算每个进程的完成时间,周转时间和带权周转时间,并且统计n个进程的平均周转时间和平均带权周转时间

2、。程序要求如下:1)进程个数n;每个进程的到达时间T1, ,Tn和服务时间S1, ,Sn;选择算法1-FCFS,2-SJF。2)要求采用先来先服务FCFS和短作业优先SJF分别调度进程运行,计算每个进程的周转时间,带权周转时间,并且计算所有进程的平均周转时间,带权平均周转时间;3)输出:要求模拟整个调度过程,输出每个时刻的进程运行状态,如“时刻3:进程B开始运行”等等;4)输出:要求输出计算出来的每个进程的周转时间,带权周转时间,所有进程的平均周转时间,带权平均周转时间。实现提示:用C+语言实现提示:1)程序中进程调度时间变量描述如下:static int MaxNum=100;int Arr

3、ivalTimeMaxNum;int ServiceTimeMaxNum;int FinishTimeMaxNum;int WholeTimeMaxNum;double WeightWholeTimeMaxNum;double AverageWT_FCFS,AverageWT_SJF; double AverageWWT_FCFS,AverageWWT_SJF;2)进程调度的实现过程如下: 变量初始化; 接收用户输入n,T1, ,Tn,S1, ,Sn;算法选择1-FCFS,2-SJF; 按照选择算法进行进程调度,计算进程的完成时间、周转时间和带权周转时间; 计算所有进程的平均周转时间和平均带权

4、周转时间; 按格式输出调度结果。实验要求:1)上机前认真复习FCFS和SJF进程调度调度算法,熟悉进程调度的执行过程;2)上机时独立编程、调试程序;3)根据具体实验要求,完成好实验报告(包括实验的目的、内容、要求、源程序、实例运行结果截图)。【源程序】头文件FCFS.h#include#define MaxNum 100struct Process_structint Number; /进程编号char NameMaxNum; /进程名称 int ArrivalTime; /到达时间int ServiceTime; /开始运行时间int FinishTime; /运行结束时间int Whole

5、Time; /运行时间 int run_flag; /调度标志int order; /运行次序double WeightWholeTime; /周转时间double AverageWT_FCFS,AverageWT_SJF; /平均周转时间 double AverageWWT_FCFS,AverageWWT_SJF; /平均带权周转时间ProcessMaxNum;int N; /实际进程个数int FCFS(); /先来先服务int FCFS() /先来先服务算法int i;int temp_time=0; /当前时间temp_time=Process0.ArrivalTime;for(i=0

6、;iN;i+) Processi.ServiceTime=temp_time;Processi.FinishTime=Processi.ServiceTime+Processi.WholeTime;Processi.run_flag=1; temp_time=Processi.FinishTime;Processi.order=i+1;return 0;头文件SJF.h#includeint SJF(); /短作业优先int SJF() /短作业优先算法int temp_time=0; /当期那时间int i=0,j;int number_schedul,temp_counter; /进程编号

7、,当前已执行进程个数float run_time;run_time=Processi.WholeTime;j=1;while(jN)&(Processi.ArrivalTime=Processj.ArrivalTime) /判断是否有两个进程同时到达if(Processj.WholeTimeProcessi.WholeTime)run_time=Processi.WholeTime;i=j;j+;/查找下一个被调度的进程/对找到的下一个被调度的进程求相应的参数number_schedul=i;Processnumber_schedul.ServiceTime=Processnumber_sch

8、edul.ArrivalTime;Processnumber_schedul.FinishTime=Processnumber_schedul.ServiceTime+Processnumber_schedul.WholeTime;Processnumber_schedul.run_flag=1;temp_time=Processnumber_schedul.FinishTime; Processnumber_schedul.order=1;temp_counter=1;while(temp_counterN)for(j=0;jN;j+)if(Processj.ArrivalTime=temp

9、_time)&(!Processj.run_flag)run_time=Processj.WholeTime;number_schedul=j;break;for(j=0;jN;j+)if(Processj.ArrivalTime=temp_time)&(!Processj.run_flag)if(Processj.WholeTimerun_time)run_time=Processj.WholeTime;number_schedul=j;/查找下一个被调度的进程/对找到的下一个被调度的进程求相应的参数Processnumber_schedul.ServiceTime=temp_time;Pr

10、ocessnumber_schedul.FinishTime=Processnumber_schedul.ServiceTime+Processnumber_schedul.WholeTime;Processnumber_schedul.run_flag=1;temp_time=Processnumber_schedul.FinishTime;temp_counter+;Processnumber_schedul.order=temp_counter;return 0;主程序Main.cpp#include#include FCFS.h#include SJF.husing namespace

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

12、();break;int Pinput() /进程参数输入int i;printf(please input the process number:n);scanf(%d,&N);for(i=0;iN;i+)printf(*n);printf(please input the process of %d th:n,i+1);printf(please input the name:n);scanf(%s,Processi.Name); printf(please input the ArrvialTime:n);scanf(%d,&Processi.ArrivalTime);printf(please input the WholeTime:n);scanf(%d,&Processi.WholeTime);Processi.ServiceTime=0;Processi.FinishTime=0;Processi.WeightWholeTime=0;Processi.order=0;Processi.run_flag=0;return 0;int Poutput() /调度结果输出int i;float turn_round_time=0,f1,w=0;printf(进程名称 到达时间 运行时间 开始运行时间 结束时间

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号