1、scheduleAtFixedRate 方法,顾名思义,它的方法名称的意思是:已固定的频率来执行某项计划(任务)。
2、scheduleWithFixedDealy,相对固定的延迟后,执行某项计划。
第一个方法是固定的频率来执行某项计划,它不受计划执行时间的影响。到时间,它就执行。
而第二个方法,相对固定,据鄙人理解,是相对任务的。即无论某个任务执行多长时间,等执行完了,我再延迟指定的时间。也就是第二个方法,它受计划执行时间的影响。
两种方法,对异常都很敏感,一旦有异常,线程(非线程池)后续该任务不再执行,解决方案是对run函数全程try catch保护
ScheduledExecutorService | Timer | |
scheduleAtFixedRate | scheduleAtFixedRate | 固定间隔 |
scheduleWithFixedDealy | schedule | 固定频率 |
异常 | |||
Timer | 单线程 | 多个任务顺序执行,不同任务会延时 | 线程池所有任务挂掉 |
ScheduledExecutorService | 指定线程 | 多个任务并发执行,只要线程够,多个任务排除自身运行太久,都能准时执行 将corePoolSize设置为1,变成单线程跑呢?结果当然是和Timer一样,任务B会导致任务A延迟执行,不过比较好的是任务C抛异常不会影响到其他任务的调度。 | 线程下后续该任务挂掉 |
https://blog.csdn.net/guozebo/article/details/51090612
package Thread;
import java.util.TimerTask;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
/**
* Created by sunyuming on 18/10/23.
*/
public class MySchedule {
public static void main(String[] args) {
int corePoolSize = 1;
ScheduledExecutorService pool = Executors.newScheduledThreadPool(corePoolSize);
pool.scheduleAtFixedRate(new TimerTask() {
@Override
public void run() {
System.out.println('a');
}
}, 0, 10, TimeUnit.SECONDS);
pool.scheduleAtFixedRate(new TimerTask() {
@Override
public void run() {
System.out.println('b');
}
}, 0, 10, TimeUnit.SECONDS);
pool.scheduleAtFixedRate(new TimerTask() {
@Override
public void run() {
System.out.println('c');
throw new RuntimeException("test");
}
}, 0, 10, TimeUnit.SECONDS);
}
}
a
b
c
a
b
a
b