前言
项目开启立即启动定时任务是很多项目都会遇到的一个需求,如何利用Java提供的函数优雅的写出来,则十分考验一个猿人的功底。更多线程知识内容请点击【Java 多线程和锁知识笔记系列】。
Supplier + ScheduledExecutorService
Java8中给我们提供了一系列的函数式接口,能够活用这些函数式接口减少代码的冗余,使得代码更加易读就十分考验开发的功底,今天结合一个Run起来就批量启动的定时任务项目需求,做一个Supplier + ScheduledExecutorService的组合,直接贴代码供大家参考。
先简单写两个任务类作为模拟定时启动的任务。
public class ScheduleTask1 implements Runnable{
@Override
public void run() {
System.out.println("++++++++++");
}
}
public class ScheduleTask2 implements Runnable{
@Override
public void run() {
System.out.println("-------------");
}
}
启动方法,利用静态方法+Supplier直接启动定时线程池,并且把所有需要执行的任务添加到池子中,达到启动即执行的目的。
public class ScheduleTest {
private static final ScheduleTask1 task1=new ScheduleTask1();
private static final ScheduleTask2 task2=new ScheduleTask2();
//利用静态方法+Supplier直接启动定时线程池,并且把所有需要执行的任务添加到池子中
private static final ScheduledExecutorService schedulePool=((Supplier<ScheduledExecutorService>)()->{
ScheduledExecutorService schedule= Executors.newScheduledThreadPool(2);
schedule.scheduleAtFixedRate(task1,0,1,TimeUnit.SECONDS);
schedule.scheduleAtFixedRate(task2,0,2,TimeUnit.SECONDS);
return schedule;
}).get();
public static void main(String[] args) throws InterruptedException {
System.out.println("Start");
}
}