进程调度算法实验报告(共13页).doc
《进程调度算法实验报告(共13页).doc》由会员分享,可在线阅读,更多相关《进程调度算法实验报告(共13页).doc(13页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上操作系统实验报告(二)实验题目:进程调度算法实验环境:C+实验目的:编程模拟实现几种常见的进程调度算法,通过对几组进程分别使用不同的调度算法,计算进程的平均周转时间和平均带权周转时间,比较各种算法的性能优劣。实验内容:编程实现如下算法:1.先来先服务算法;2.短进程优先算法;3.时间片轮转调度算法。设计分析:程序流程图:1.先来先服务算法初始化PCB,输入进程信息开始各进程按先来先到的顺序进入就绪队列就绪队列?结束运行运行进程所需CPU时间取消该进程2.短进程优先算法3.时间片轮转调度算法实验代码:1. 先来先服务算法#include #define n 20type
2、def struct int id; /进程名int atime; /进程到达时间int runtime; /进程运行时间fcs;void main()int amount,i,j,diao,huan; fcs fn;cout请输入进程个数:amount;for(i=0;iamount;i+) cout请输入进程名,进程到达时间,进程运行时间:fi.id; cinfi.atime; cinfi.runtime;for(i=0;iamount;i+) /按进程到达时间的先后排序 /如果两个进程同时到达,按在屏幕先输入的先运行 for(j=0;jfj+1.atime) diao=fj.atime;
3、 fj.atime=fj+1.atime; fj+1.atime=diao; huan=fj.id; fj.id=fj+1.id; fj+1.id=huan; for(i=0;iamount;i+) cout进程:fi.id从fi.atime开始,在 fi.atime+fi.runtime之前结束。endl; fi+1.atime=fi.atime+fi.runtime;2. 短进程优先算法#include#define n 5#define num 5#define max 65535typedef struct pro int PRO_ID; int arrive_time;int sum
4、_time;int flag;Pro;/整数排序 int bubble(int temp) int i,j,tem=0; for(i=1;inum;i+) int lastX=1;for(j=0;jtempj+1) tem=tempj; tempj=tempj+1; tempj+1=tem; lastX=0;if(lastX=1) break;return temp0; /进程排序 Pro bubble(Pro p) int i,j;Pro temp=0;Pro snum;for(i=0;inum;i+) si=pi; for(i=1;inum;i+)int lastX=1;for(j=0;j
5、sj+1.sum_time) temp=sj; sj=sj+1; sj+1=temp; lastX=0;if(lastX=1) break;return s0; void SPF(int p)if(n0) int i,j,k,l,tc=0;Pro seqn;Pro temp_seqn;printf(短进程优先调度算法SPFn);printf(请依次输入5个进程的进程号、到达时间和执行时间n);printf(成员变量用逗号隔开;进程间用回车隔开n); for(i=0;in;i+) scanf(%d,%d,%d,&seqi.PRO_ID,&seqi.arrive_time,&seqi.sum_ti
6、me);printf(调度顺序是:n);/初始化tcint tempnum;for(i=0;inum;i+) tempi=seqi.arrive_time;tc=bubble(temp);/tc是断点啊 /flag 表示对应i的pro的队列情况/-1表示未进入过队列,0表示在队列中,1表示被清除了for(i=0;in;i+)seqi.flag=-1; for(i=0;in;i+) for(j=0;jn;j+) if(seqj.flag!=1&seqj.arrive_time=tc) seqj.flag=0; for(j=0;jn;j+) temp_seqj=seqj; if(seqj.flag
7、!=0) temp_seqj.sum_time=max; l=bubble(temp_seq).PRO_ID;for(j=0;jn;j+)if(l=seqj.PRO_ID)k=j; tc=tc+bubble(temp_seq).sum_time; seqk.flag=1; printf(%d,l);printf(n);void main()SPF(n);3. 时间片轮转调度算法头文件RR.h#include#include#include#include#include#define MaxNum 100typedef struct pcb /定义进程控制块char NameMaxNum; /
8、进程名int arrivetime; /到达时间int runtime; /运行时间int wholetime; /固定运行时间int FinishTime; /完成时间double WeightTime; /周转时间double WeightWholeTime; /带权周转时间char state; /运行后的状态struct pcb *next;PCB;/全局变量int N; /实际进程数double SumWT; /周转时间之和double SumWWT; /带权周转时间之和double AverageWT; /平均周转时间double AverageWWT; /平均带权周转时间type
9、def struct /定义队列,封装头结点,指针分别指向队头和队尾PCB *front,*rear;queue;queue *init() /进程队列置空queue *head;head=(queue*)malloc(sizeof(queue);head-front=NULL;head-rear=NULL;return head;int empty(queue *head) /检验队列是否为空return (head-front?0:1);queue *append(queue *head,char cMaxNum,int a,int r,char s) /进程队列入队,往后插入PCB *p
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 进程 调度 算法 实验 报告 13
限制150内