先来先服务和短作业优先调度算法

2024-01-05 06:32

本文主要是介绍先来先服务和短作业优先调度算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先来先服务调度算法:系统按照作业到达的先后次序来进行调度,或者说它优先考虑在系统中等待时间最长的作业,而不管该作业所需执行时间的长短,从后备作业队列中选择几个最先进入该队列的作业,将它们调入内存,为它们分配资源和创建进程。然后把它放入就绪队列。

当进程调度中才有FCFS算法时,每次调度是从就绪的进程队列中选择一个最先进入该队列的进程,为之分配处理机,使之投入运行。该进程一直运行到完成或发生某事件而阻塞后,进程调度程序才将处理机分配给其他进程。

短作业优先调度算法:SJF算法是以作业的长短来计算优先级,作业越短,其优先级越高。作业的长短是以作业所要求的运行时间来衡量的。SJF算法可以分别用于作业调度和进程调度。在把短作业优先调度算法用于作业调度时,它将从外存的作业后备队列中选择若干个估计运行时间最短的作业,优先将它们调入内存运行。

#include<stdio.h>
#include<string.h> 
#include <stdlib.h>
#define N 10				//允许最大进程个数
#define M 100				//进程名长度 
int n;						//进程个数 
char name[N][M]; 			//进程名 
int Arival[N]={0};			//到达时间 
int Go[N]={0};				//运行时间 
int Start[N]={0};			//开始时间 
int End[N]={0};				//结束时间 
int Timer[N]={0};			//周转时间 
float DTimer[N]={0};		//带权周转时间 
int Check[N]={0};			//判断作业是否完成,完成值为1
/*输入函数*/
void input(){//为测试方便,采用输入重定义处理//每次读取当前文件夹下in.txt文件// 若文件不存在,则手动输入 int i;FILE *fin;  if((fin=fopen("in.txt","rb"))==NULL){printf("进程的个数:");scanf("%d",&n);for(i=0;i<n;i++){printf("进程名:");scanf("%s",&name[i]);printf("第%d个进程的到达时间:",i+1);scanf("%d",Arival+i);printf("第%d个进程的运行时间:",i+1);scanf("%d",Go+i);}}else{for(i=0;!feof(fin);i++){fscanf(fin,"%s",&name[i]);fscanf(fin,"%d",Arival+i);fscanf(fin,"%d",Go+i);}  n=i; } 
}/**选出先到达的作业 *a[] 到达时间 *n 进程个数 **/
int Select0(int a[],int n){int i=0;for(int k=0;k<n;k++){if(Check[k]==0){i=k;break;}}for(int j=0;j<n;j++){if(a[i]>a[j]&&Check[j]==0){i=j;}}Check[i]=1;return i;
}
/*先来先服务调度算法*/
void fcfs(){int k=0;			//每次选出即将服务的进程 int l=0;			//本次服务的进程 int Atimer=0;		//周转时间之和float timer=0;		//带权周转时间之和 //每次开始之前Check数组要全部置0memset(Check,0,sizeof(Check));k=Select0(Arival,n);Start[k]=Arival[k];End[k]=Start[k]+Go[k];Timer[k]=End[k]-Arival[k];DTimer[k]=(float)Timer[k]/Go[k];printf("作业  提交时间  运行时间  开始时间  结束时间  周转时间  带权周转时间\n");for(int m=0;m<n;m++){l=k;k=Select0(Arival,n);Start[k]=End[l];End[k]=Start[k]+Go[k];Timer[k]=End[k]-Arival[k];DTimer[k]=(float)Timer[k]/Go[k];Atimer=Timer[l]+Atimer;timer=timer+DTimer[l];printf(" %s     %2d        %2d         %2d        %2d        %2d         %.2f\n",name[l],Arival[l],Go[l],Start[l],End[l],Timer[l],DTimer[l]);}printf("平均周转时间:%.2f\n",(float)Atimer/n);printf("平均带权周转时间:%.2f\n",(float)timer/n);
}
/**选出短作业 *a[] 运行时间 *n 进程个数 *local 当前时间 **/
int Select1(int a[],int n,int local){int i=0;for(int k=0;k<n;k++){if(Check[k]==0){i=k;break;}}for(int j=0;j<n;j++){if(a[i]>a[j]&&Check[j]==0&&Arival[j]<=local){i=j;}}Check[i]=1;return i;
}
/*短作业优先调度算法*/
void sjf(){int k=0;			//每次选出即将服务的进程 int l=0;			//本次服务的进程 int Atimer=0;		//周转时间之和float timer=0;		//带权周转时间之和 int localtime=0;	//当前时间 //每次开始之前Check数组要全部置0memset(Check,0,sizeof(Check));Start[k]=Arival[k];End[k]=Start[k]+Go[k];Timer[k]=End[k]-Arival[k];DTimer[k]=(float)Timer[k]/Go[k];localtime=End[k];Check[k]=1;printf("作业  提交时间  运行时间  开始时间  结束时间  周转时间  带权周转时间\n");for(int m=0;m<n;m++){l=k;k=Select1(Go,n,localtime);Start[k]=End[l];End[k]=Start[k]+Go[k];Timer[k]=End[k]-Arival[k];DTimer[k]=(float)Timer[k]/Go[k];localtime=End[k];Atimer=Timer[l]+Atimer;timer=timer+DTimer[l];printf(" %s     %2d        %2d         %2d        %2d        %2d         %.2f\n",name[l],Arival[l],Go[l],Start[l],End[l],Timer[l],DTimer[l]);}printf("平均周转时间:%.2f\n",(float)Atimer/n);printf("平均带权周转时间:%.2f\n",(float)timer/n);
} 
void menu(){int choice;while(1){printf("*******请选择调度算法*******\n\t1、先来先服务\n\t2、短作业优先\n\t0、退出\n请输入:");scanf("%d",&choice);if(choice==0){break;}else if(choice==1){fcfs();}else if(choice==2){sjf(); }else{printf("输入有误!\n");		}}	
}
int main(){input();menu();return 0;
}

为测试方便,采用输入重定向的方法,每次读取当前程序文件目录下的in.txt文件,若文件不存在则手动输入。

 

in.txt文件内容如下:

内容格式依次为:作业名、到达时间、服务时间

 

测试结果如下:

若文件不存在,则手动输入,结果如下:

 

 

 

这篇关于先来先服务和短作业优先调度算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/571949

相关文章

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

springboot的调度服务与异步服务使用详解

《springboot的调度服务与异步服务使用详解》本文主要介绍了Java的ScheduledExecutorService接口和SpringBoot中如何使用调度线程池,包括核心参数、创建方式、自定... 目录1.调度服务1.1.JDK之ScheduledExecutorService1.2.spring

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后