非抢占式高优先级调度算法_剥夺式优先级调度算法

2020-02-29 其他范文 下载本文

非抢占式高优先级调度算法由刀豆文库小编整理,希望给你工作、学习、生活带来方便,猜你可能喜欢“剥夺式优先级调度算法”。

/* 非抢占式高优先级调度算法(优先数越大级别越高)

算法思想:在按进程达到时间由小到大的顺序输入进程信息后,先对其优先数进行排列,将最先到达的进程的到达时间设为开始时间,计算结束时间,然后对后面到达的时间与该进程的结束时间进行比较,如若小于该进程的结束时间,记录进程的个数,再对其优先数逐个进行比较,将优

先数最大的提到前面,每次进程结束都要进行比较,得到执行序列,在依次输出结果 */ #include #define MAX 100 struct hrfs { char name[10];float arrvitetime;float starttime;float servietime;float finishtime;int priority;//优先数

int order;//进程执行次序

int run_flag;//标记进程状态 };

hrfs p[MAX];int count;//排列到达时间

//按到达时间与优先数计算执行序列 void HRfs(){ float temp_time=0;int i=0,j;int k,temp_count;int max_priority;max_priority=p[i].priority;j=1;while((j

if(p[j].priority>p[i].priority){

max_priority=p[j].priority;

i=j;

}

j++;} k=i;p[k].starttime=p[k].arrvitetime;//开始时间=达到时间

p[k].finishtime=p[k].starttime+p[k].servietime;p[k].run_flag=1;temp_time=p[k].finishtime;p[k].order=1;temp_count=1;while(temp_count

max_priority=0;

for(j=0;j

//判断到达时间是否小于上一个进程的结束时间并且非处在运行状态

if((p[j].arrvitetime

//判断进程优先数是否大于最大优先数,如果大于,就将其值赋给max_priority

if(p[j].priority>max_priority){

max_priority=p[j].priority;

k=j;

}

}

p[k].starttime=temp_time;

p[k].finishtime=p[k].starttime+p[k].servietime;

p[k].run_flag=1;

temp_time=p[k].finishtime;

temp_count++;

p[k].order=temp_count;} }

void input(){ int i;printf(“n请输入进程名 到达时间 运行时间 优先数,例如:a 0 100 1n”);for(i=0;i

printf(“进程%d的信息:”,i+1);

scanf(“%s%f%f%d”,p[i].name,&p[i].arrvitetime,&p[i].servietime,&p[i].priority);

p[i].starttime=0;

p[i].finishtime=0;

p[i].order=0;

p[i].run_flag=0;} } void print(){ int i;float turn_round_time=0,f1,w=0;float right_turn_round_time;printf(“n进程完成信息-----n”);printf(“进程名 优先级 达到时间 运行时间 开始时间 结束时间

周转时间 带权周转时间 运行次序n”);for(i=0;i

f1=p[i].finishtime-p[i].arrvitetime;

turn_round_time+=f1;

right_turn_round_time=f1/p[i].servietime;

w+=(f1/p[i].servietime);

printf(“%s %5d %10.2f %8.2f %8.2f %8.2f %8.2f %8.2f %8dn”,p[i].name,p[i].priority,p[i].arrvitetime,p[i].servietime,p[i].starttime,p[i].finishtime,f1,right_turn_round_time,p[i].order);} printf(“平均周转时间=%5.2fn”,turn_round_time/count);printf(“平均带权周转时间=%5.2fn”,w/count);}

void main(){ printf(“---------------------------非抢占式高优先级调度算法----------------------------n”);printf(“进程个数:”);scanf(“%d”,&count);input();HRfs();

print();}

《非抢占式高优先级调度算法.docx》
将本文的Word文档下载,方便收藏和打印
推荐度:
非抢占式高优先级调度算法
点击下载文档
相关专题 剥夺式优先级调度算法 优先级 算法 剥夺式优先级调度算法 优先级 算法
[其他范文]相关推荐
    [其他范文]热门文章
      下载全文