美文网首页
Java中的任务调度

Java中的任务调度

作者: 冰花水焰 | 来源:发表于2020-12-03 21:43 被阅读0次

    前言

    任务调度是指基于给定时间点,给定时间间隔或者给定执行次数自动执行任务。本文介绍前两种任务调度的 Java 实现:

    • Timer
    • ScheduledThreadPoolExecutor
    • 开源工具包 Quartz
    • 开源工具包 JCronTab

    Timer

    import java.util.Timer;
    import java.util.TimerTask;
    
    public class TimerTest {
        public static void main(String[] args) {
            Timer timer = new Timer();
            timer.schedule(new TimerTask() {
                @Override
                public void run() {
                    System.out.println("你是zz");
                    try{Thread.sleep(1000);}catch (Exception e){}
                }
            }, 1000);
    
            timer.schedule(new TimerTask() {
                @Override
                public void run() {
                    System.out.println("你是xx");
    
                }
            }, 1000);
        }
    
    
    }
    

    使用 Timer 实现任务调度的核心类是 Timer 和 TimerTask。其中 Timer 负责设定 TimerTask 的起始与间隔执行时间。使用者只需要创建一个 TimerTask 的继承类,实现自己的 run 方法,然后将其丢给 Timer 去执行即可。


    Timer 的设计核心是一个 TaskList 和一个 TaskThread。Timer 将接收到的任务丢到自己的 TaskList 中,TaskList 按照 Task 的最初执行时间进行排序。TimerThread 在创建 Timer 时会启动成为一个守护线程。这个线程会轮询所有任务,找到一个最近要执行的任务,然后休眠,当到达最近要执行任务的开始时间点,TimerThread 被唤醒并执行该任务。之后 TimerThread 更新最近一个要执行的任务,继续休眠。


    Timer 的优点在于简单易用,但由于所有任务都是由同一个线程来调度,因此所有任务都是串行执行的,同一时间只能有一个任务在执行,前一个任务的延迟或异常都将会影响到之后的任务。


    ScheduledThreadPoolExecutor

    鉴于 Timer 的上述缺陷,Java 5 推出了基于线程池设计的 ScheduledExecutor。其设计思想是,每一个被调度的任务都会由线程池中一个线程去执行,因此任务是并发执行的,相互之间不会受到干扰。需要注意的是,只有当任务的执行时间到来时,ScheduedExecutor 才会真正启动一个线程,其余时间 ScheduledExecutor 都是在轮询任务的状态。

    import java.util.concurrent.ScheduledThreadPoolExecutor;
    import java.util.concurrent.TimeUnit;
    
    public class ScheduleExecutorTest {
        public static void main(String[] args) {
            ScheduledThreadPoolExecutor scheduledThreadPoolExecutor = new ScheduledThreadPoolExecutor(10);
            scheduledThreadPoolExecutor.schedule(new Runnable() {
                @Override
                public void run() {
                    System.out.println("hahahah"+Thread.currentThread().getName());
                }
            }, 1, TimeUnit.SECONDS);
            scheduledThreadPoolExecutor.scheduleAtFixedRate(new Runnable() {
                @Override
                public void run() {
                    System.out.println("wobushi hanhan"+Thread.currentThread().getName());
                }
            },5, 1, TimeUnit.SECONDS);
        }
    }
    
    

    参考文章

    相关文章

      网友评论

          本文标题:Java中的任务调度

          本文链接:https://www.haomeiwen.com/subject/turvwktx.html