使用 Executors.newScheduledThreadPool(10); 的任务调度
来源:互联网 发布:产品怎样做网络销售 编辑:程序博客网 时间:2024/06/05 06:09
ScheduledExecutor
鉴于 Timer 的上述缺陷,Java 5 推出了基于线程池设计的 ScheduledExecutor。其设计思想是,每一个被调度的任务都会由线程池中一个线程去执行,因此任务是并发执行的,相互之间不会受到干扰。需要注意的是,只有当任务的执行时间到来时,ScheduedExecutor 才会真正启动一个线程,其余时间 ScheduledExecutor 都是在轮询任务的状态。
清单 2. 使用 ScheduledExecutor 进行任务调度
package com.ibm.scheduler;import java.util.concurrent.Executors;import java.util.concurrent.ScheduledExecutorService;import java.util.concurrent.TimeUnit;public class ScheduledExecutorTest implements Runnable {private String jobName = "";public ScheduledExecutorTest(String jobName) {super();this.jobName = jobName;}@Overridepublic void run() {System.out.println("execute " + jobName);}public static void main(String[] args) {ScheduledExecutorService service = Executors.newScheduledThreadPool(10);long initialDelay1 = 1;long period1 = 1; // 从现在开始1秒钟之后,每隔1秒钟执行一次job1service.scheduleAtFixedRate( new ScheduledExecutorTest("job1"), initialDelay1,period1, TimeUnit.SECONDS);long initialDelay2 = 1;long delay2 = 1; // 从现在开始2秒钟之后,每隔2秒钟执行一次job2service.scheduleWithFixedDelay( new ScheduledExecutorTest("job2"), initialDelay2,delay2, TimeUnit.SECONDS);}}Output:execute job1execute job1execute job2execute job1execute job1execute job2
清单 2 展示了 ScheduledExecutorService 中两种最常用的调度方法 ScheduleAtFixedRate 和 ScheduleWithFixedDelay。ScheduleAtFixedRate 每次执行时间为上一次任务开始起向后推一个时间间隔,即每次执行时间为 :initialDelay, initialDelay+period, initialDelay+2*period, …;ScheduleWithFixedDelay 每次执行时间为上一次任务结束起向后推一个时间间隔,即每次执行时间为:initialDelay, initialDelay+executeTime+delay, initialDelay+2*executeTime+2*delay。由此可见,ScheduleAtFixedRate 是基于固定时间间隔进行任务调度,ScheduleWithFixedDelay 取决于每次任务执行的时间长短,是基于不固定时间间隔进行任务调度。
几种任务调度的 Java 实现方法与比较
http://www.ibm.com/developerworks/cn/java/j-lo-taskschedule/
- 使用 Executors.newScheduledThreadPool(10); 的任务调度
- Executors.newFixedThreadPool / Executors.newScheduledThreadPool 例子
- spring任务调度的使用
- 任务调度的使用crontab
- 线程池的使用(newCachedThreadPool、newFixedThreadPool、newScheduledThreadPool、newSingleThreadExecutor)
- Quartz任务调度的使用(lp)
- 定时任务调度器Quartz的使用
- 基于quartz任务调度组件的使用
- quartz任务调度框架的简单使用
- linux任务调度命令crontab的使用
- Linux crontab 任务调度的使用
- 简单的使用java Timer调度任务
- 任务调度器quartz的使用
- Linux 任务调度crontab的使用
- Spring任务调度器Task的使用
- Linux 任务调度服务crond的使用
- quartz任务调度框架的使用
- Executors 四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor
- 不良代码展示-尽量强制转换减少toString()的调用
- ORACLE EBS 系统主数据管理(G)
- ORACLE EBS 系统主数据管理(H)
- Ios XML 不同解析方法比较
- 初始社会网络分析
- 使用 Executors.newScheduledThreadPool(10); 的任务调度
- ORACLE EBS 系统主数据管理(I)
- 总线的半同步通信
- 最新行政区代码(2010-12-31) SQL语句
- HashTable,HashMap和TreeMap
- MySQL关联查询优化实例
- ORACLE EBS 系统主数据管理(J)
- 解压cpio.gz文件
- 终于搞定使用node.js +redis 作为服务端,提供图片上传存储服务