最近工作中用Executors.newSingleThreadScheduledExecutor()实现了一个定时任务
该任务会在一次任务执行完毕后的间隔时间才会执行下一次任务
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class Task {
/**定时任务
* @param args
*/
public static void main(String[] args) {
Runnable runnable = new Runnable() {
int i=1;
public void run() {
System.out.println(i);
i++;
};
};
ScheduledExecutorService service = Executors.newSingleThreadScheduledExecutor();
// 1表示时间单位的数值 TimeUnit.SECONDS 延时单位为秒
service.scheduleAtFixedRate(runnable, 0, 1, TimeUnit.SECONDS);
}
}
运行结果:
而当执行过程中发生异常时却不报错卡死 :
控制台输出到4就卡死 程序没有中断也没有异常抛出
为什么会这样呢 原来在源码的Java doc中的发现了如下一句话:If any execution of the task encounters an exception, subsequent executions are suppressed.Otherwise, the task will only terminate via cancellation or termination of the executor.
简单总结就是:如果定时任务执行过程中遇到发生异常,则后面的任务将不再执行。
所以我们要如何解决呢 很简单 一个try/catch轻松解决
下面我们再次修改代码:
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
public class Task {
/**
* 定时任务
*
* @param args
*/
public static void main(String[] args) {
Runnable runnable = new Runnable() {
int i = 1;
public void run() {
try {
System.out.println(i);
i++;
// i为5时发生by zero异常
if (i == 5) {
int a = 1 / 0;
}
} catch (Exception e) {
System.out.println("发生异常");
}
};
};
ScheduledExecutorService service = Executors.newSingleThreadScheduledExecutor();
// TimeUnit.SECONDS 延时单位为秒
service.scheduleAtFixedRate(runnable, 0, 1, TimeUnit.SECONDS);
}
}
执行结果:
可以看到当发生异常时 捕捉异常后没有像上次一样程序卡死 而是在下一个执行时间继续执行了任务.
至此完美解决 担心任务卡死挂掉的问题