高响应比优先调度算法和短作业优先调度算法

举报
振华OPPO 发表于 2022/03/05 15:28:31 2022/03/05
【摘要】 动态优先权是指在创建进程时所赋予的优先权,是可以随进程的推进或随其等待时间的增加而改变的,以便获得更好的调度性能。引入动态优先权,并使作业的优先权随其等待时间的增长,其优先权以速率a提高。优先权的变化规律可描述为:优先权=(等待时间+要求服务时间)/要求服务时间本实验模拟了高响应比优先调度算法。假如系统中现有3个作业,分别为A、B、C,它们的作业大小、需要磁带机数、需要打印机数,在外存上等待...

动态优先权是指在创建进程时所赋予的优先权,是可以随进程的推进或随其等待时间的增加而改变的,以便获得更好的调度性能。引入动态优先权,并使作业的优先权随其等待时间的增长,其优先权以速率a提高。优先权的变化规律可描述为:

优先权=(等待时间+要求服务时间)/要求服务时间

本实验模拟了高响应比优先调度算法。
假如系统中现有3个作业,分别为A、B、C,它们的作业大小、需要磁带机数、需要打印机数,在外存上等待的时间以及估计需要执行时间分别是:
A 5 2 1 3 10
B 3 3 2 4 6
C 7 1 2 2 14
按高响应比优先算法,假如要选一个作业,你认为选择哪个作业进行调度? B

1.打开“Microsoft Visual C++ 6.0”,输入相关代码后,对程序行进编译运行后,将前述的三个作业A、B、C的相关数据依次输入,得到运行结果:
在这里插入图片描述
2.将程序改为短作业优先算法,给出程序修改位置以及所改代码:
修改位置

if(jobtable[p].length<=memory&&jobtable[p].tape<=tape&&jobtable[p].printer<=printer){
			 xk=(float)(jobtable[p].waittime+jobtable[p].runtime)/jobtable[p].runtime;
			 if(q==0||xk>k) {	
					k=xk;
					q=p;
					t=s;
				}
			}

所改代码

if(jobtable[p].length<=memory&&jobtable[p].tape<=tape&&jobtable[p].printer<=printer){
			 xk=(float)(jobtable[p].runtime);
			 if(q==0||xk<jobtable[p+1].runtime) {	
					k=xk;
					q=p;
					t=s;
				}
			}

3.短作业优先算法中输入相同的三个作业A、B、C的相关数据,得到运行结果:
在这里插入图片描述
——————————————————————————————————————————————————————————————————————————————————————
附上高响应比优先调度算法:

#include"string.h"
#define n 10
typedef struct jcb {
	char name[4];  
	int length;  
	int printer;  
	int tape;  
	int runtime;  
	int waittime;  
	int next;  
}JCB;
int head;
int tape,printer;
long memory;
JCB jobtable[n]; 
int jobcount=0;  
shedule(){
	 float xk,k;
	 int p,q,s,t;
	 do{
		p=head;
		q=s=-1;
		k=0;
		while(p!=-1){
			 if(jobtable[p].length<=memory&&jobtable[p].tape<=tape&&jobtable[p].printer<=printer){
			 xk=(float)(jobtable[p].waittime+jobtable[p].runtime)/jobtable[p].runtime;
			 if(q==0||xk>k) {	
					k=xk;
					q=p;
					t=s;
				}
			}
			 s=p;
			 p=jobtable[p].next; 
		} 
		if(q!=-1){
			if(t==-1)  
				head=jobtable[head].next;
		else
				jobtable[t].next=jobtable[q].next;   
		memory=memory-jobtable[q].length;
		tape=tape-jobtable[q].tape;  
		printer=printer-jobtable[q].printer;  
		printf("选中的作业的作业名: %s\n",jobtable[q].name);
		}
	 }	while(q!=-1);
}
void main(){
	char name[4];
	int size,tcount,pcount,wtime,rtime; 
	int p;
	memory=65536; 
	tape=4;
	printer=2;
	head=-1;
	printf("请输入作业相关数据(以作业大小为负数停止输入):\n");
	printf("输入作业名 作业大小 磁带机数 打印机数 等待时间 估计运行时间\n");
	scanf("%s %d %d %d %d %d",name,&size,&tcount,&pcount,&wtime,&rtime);
	while(size!=-1)
	{
		if(jobcount<n)
			p=jobcount;
		else
		{
			printf("无法在创建作业\n");
			break;
		}
		 jobcount++;
		 strcpy(jobtable[p].name,name);
		 jobtable[p].length=size;
		 jobtable[p].printer=pcount;
		 jobtable[p].tape=tcount;
		 jobtable[p].runtime=rtime;
		 jobtable[p].waittime=wtime;
		 jobtable[p].next=head;  
		 head=p;   
		 printf("输入作业名 作业大小 磁带机数 打印机数 等待时间 估计运行时间\n");
		 scanf("%s %d %d %d %d %d",name,&size,&tcount,&pcount,&wtime,&rtime);
	}
	 shedule(); 
	 return;
}

附上短作业优先调度算法:

#include"string.h"
#define n 10
typedef struct jcb {
	char name[4];  
	int length;  
	int printer;  
	int tape;  
	int runtime;  
	int waittime;  
	int next;  
}JCB;
int head;
int tape,printer;
long memory;
JCB jobtable[n]; 
int jobcount=0;  
shedule(){
	 float xk,k;
	 int p,q,s,t;
	 do{
		p=head;
		q=s=-1;
		k=0;
		while(p!=-1){
			 if(jobtable[p].length<=memory&&jobtable[p].tape<=tape&&jobtable[p].printer<=printer){
			 xk=(float)(jobtable[p].runtime);
			 if(q==0||xk<jobtable[p+1].runtime) {	
					k=xk;
					q=p;
					t=s;
				}
			}
			 s=p;
			 p=jobtable[p].next; 
		} 
		if(q!=-1){
			if(t==-1)  
				head=jobtable[head].next;
		else
				jobtable[t].next=jobtable[q].next;   
		memory=memory-jobtable[q].length;
		tape=tape-jobtable[q].tape;  
		printer=printer-jobtable[q].printer;  
		printf("选中的作业的作业名: %s\n",jobtable[q].name);
		}
	 }	while(q!=-1);
}
void main(){
	char name[4];
	int size,tcount,pcount,wtime,rtime; 
	int p;
	memory=65536; 
	tape=4;
	printer=2;
	head=-1;
	printf("请输入作业相关数据(以作业大小为负数停止输入):\n");
	printf("输入作业名 作业大小 磁带机数 打印机数 等待时间 估计运行时间\n");
	scanf("%s %d %d %d %d %d",name,&size,&tcount,&pcount,&wtime,&rtime);
	while(size!=-1)
	{
		if(jobcount<n)
			p=jobcount;
		else
		{
			printf("无法在创建作业\n");
			break;
		}
		 jobcount++;
		 strcpy(jobtable[p].name,name);
		 jobtable[p].length=size;
		 jobtable[p].printer=pcount;
		 jobtable[p].tape=tcount;
		 jobtable[p].runtime=rtime;
		 jobtable[p].waittime=wtime;
		 jobtable[p].next=head;  
		 head=p;   
		 printf("输入作业名 作业大小 磁带机数 打印机数 等待时间 估计运行时间\n");
		 scanf("%s %d %d %d %d %d",name,&size,&tcount,&pcount,&wtime,&rtime);
	}
	 shedule(); 
	 return;
}

生活从来都不容易啊,当你觉得挺容易的时候,一定是有人在替你承担属于你的那份不容易 。-- 致父母 ​​​​

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。