操作系统课程设计-进程调度算法模拟_精品.doc
文本预览下载声明
操作系统课程设计
进程调度算法模拟
实验内容:
模拟五种进程调度算法并计算各参数值
实验原理:
先来先服务调度:最先到达的进程先进行调度
短作业优先调度:从已到达的进程中选出最短的进程优先调度
时间片轮转调度:每个进程依次的按时间片轮流的方式执行
静态优先权调度:赋予优先权,在已到达的进程中选出优先权最高的优先调度
高响应比优先调度:优先权随等待时间而增加,从而使等待时间较长且服务时间较短的进程优先调度
响应比=1+等待时间/服务时间
实验设计说明:
本程序采用C++ Builder 5编程和设计界面
考虑到调度算法较多,采用了多页面的界面(如下图),加入的进程限制五个,在文本框中模拟到达一进程后,输入到达时间和服务时间,点击
“加入新进程”即可,输入完成之后,点击运行即可得到表中各值。想从新输入可点击“清除”按钮。关闭时直接点击“×”即可。
该程序还不是很完善,有一些小问题,尚待解决,还得向老师请教。
实验结果:(只打印两个结果示范)
运行后操作面板初始化如下图:
短作业优先结果如图:
时间片轮转结果如图:(书上的例题)
实验源程序:
Unit1.h文件
//
#ifndef Unit1H
#define Unit1H
//
#include Classes.hpp
#include Controls.hpp
#include StdCtrls.hpp
#include Forms.hpp
#include ComCtrls.hpp
#include Grids.hpp
#include ExtCtrls.hpp
//
class TForm1 : public TForm
{
__published: // IDE-managed Components
TPageControl *PageControl1;
TTabSheet *TabSheet1;
TTabSheet *TabSheet2;
TTabSheet *TabSheet3;
TTabSheet *TabSheet4;
TabSheet *TabSheet5;
TStringGrid *sgr;
TButton *Button1;
TButton *Button2;
TButton *Button3;
TStringGrid *sgr1;
TButton *Button4;
TButton *Button5;
TButton *Button6;
TStringGrid *sgr2;
TButton *Button7;
TButton *Button8;
TButton *Button9;
TStringGrid *sgr3;
TButton *Button10;
TButton *Button11;
TButton *Button12;
TStringGrid *sgr4;
TButton *Button13;
TButton *Button14;
TButton *Button15;
TLabel *Label1;
TEdit *Edit1;
TLabel *Label2;
TEdit *Edit2;
TEdit *Edit3;
TEdit *Edit4;
TLabel *Label3;
TLabel *Label4;
TEdit *Edit5;
TLabel *Label5;
TLabel *Label6;
TEdit *Edit6;
TLabel *Label7;
TEdit *Edit7;
TLabel *Label8;
TLabel *Label9;
TLabel *Label10;
TEdit *Edit8;
TEdit *Edit9;
TEdit *Edit10;
TLabel *Label11;
TLabel *Label12;
TEdit *Edit11;
TEdit *Edit12;
void __fastcall FormCreate(TObject *Sender);
void __fastcall Button3Click(TObject *Sender);
void __fastcall Button1Click(TObject *Sender);
void __fastcall Button2Click(TObject *Sender);
void __fastcall Button6Click(TObject *Sender);
void __fastcall Button5Click(TObject *Sender);
void __fastcall Button4Click(TObject *Sender);
void __fastcall Button9Click
显示全部