Java实现先来先服务与短作业优先

2024-06-21 06:48

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

1、定义作业类

package com.ghs.job;
public class Job {/**作业编号*/private String jobId;/**运行时间*/private int runTime;public Job() {super();}public Job(String jobId, int runTime) {super();this.jobId = jobId;this.runTime = runTime;}public int getRunTime() {return runTime;}public void setRunTime(int runTime) {this.runTime = runTime;}public void excute(){System.out.println("作业"+jobId+"正在运行!");}
}

2、定义调度策略

package com.ghs.job;public enum ScheduleStrategy {FCFS,   //先来先服务SJF,    //短作业优先
}

3、实现调度
实现原理:定义一个调度进程ScheduleThread,不停的访问作业队列,如果队列不为空,就按照调度策略取得下一个需要执行的作业。
注意:由于往作业队列中添加作业和从作业队列中取作业是在两个线程内完成,所以需要加为作业队列加同步锁。

package com.ghs.job;import java.util.Collections;
import java.util.LinkedList;
import java.util.List;public class ScheduleService {private ScheduleStrategy strategy;private ScheduleThread scheduleThread = null;List<Job> jobs= Collections.synchronizedList(new LinkedList<Job>());public ScheduleService() {scheduleThread = new ScheduleThread();scheduleThread.start();}public ScheduleThread getScheduleThread() {return scheduleThread;}public void setScheduleThread(ScheduleThread scheduleThread) {this.scheduleThread = scheduleThread;}public void process(Job job){synchronized (jobs) {jobs.add(job);}}/*** 按照调度策略获取下一个要执行的作业* @return*/public Job getNextJob(){Job job = null;switch (strategy) {case FCFS:job = jobs.remove(0);break;case SJF:System.out.println(jobs.size());job = jobs.get(0);for(int i=1;i<jobs.size(); i++){if(jobs.get(i).getRunTime()<job.getRunTime()){job = jobs.get(i);}}jobs.remove(job);break;default:job = jobs.remove(0);break;}return job;}public ScheduleStrategy getStrategy() {return strategy;}public void setStrategy(ScheduleStrategy strategy) {this.strategy = strategy;}/*** 工作线程,用于执行作业* @author liu*/private class ScheduleThread extends Thread{boolean isRunning = true;@Overridepublic void run() {Job job = null;while(isRunning){synchronized (jobs) {if(!jobs.isEmpty()){job = getNextJob();}}if(job!=null){job.excute();job=null;}}}public void stopSchedule(){this.isRunning = false;}}public static void main(String[] args) {ScheduleService service = new ScheduleService();service.setStrategy(ScheduleStrategy.SJF);service.process(new Job("001",18));service.process(new Job("002",13));service.process(new Job("003",15));service.process(new Job("004",8));service.process(new Job("005",5));}
}

完整代码:http://download.csdn.net/detail/u011983531/9211495

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



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

相关文章

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一