ScheduleThreadPoolExecutor 定时任务线程池
ScheduleThreadPoolExecutor 定时任务线程池
之前讲到ThreadPoolExecutor,ScheduleThreadPoolExecutor继承自ThreadPoolExecutor,它的主要作用是用于定时任务的的线程池,给定延迟时间,来继续执行任务。
ScheduleThreadPoolExecutor比Timer使用起来更方便,也避免了因为任务抛出异常,无法在进行任务的尴尬。
定时任务实现方法
定时任务线程池接收ScheduleFutureTask类型的任务,有三种提交方式
- schedule
- scheduledAtFixedRate()方法的作用是预定在初始的延迟结束后,周期性地执行给定的任务,周期长度为period,其中initialDelay为初始延迟。此处的周期性的时间间隔指的是此次开始任务执行到下次任务开始执行的时间间隔。
public ScheduledFuture<?> scheduleAtFixedRate(Runnable command,
long initialDelay,
long period,
TimeUnit unit)
- scheduledWithFixedDelay()方法的作用是预定在初始的延迟结束后周期性地执行给定任务,在一次调用完成和下一次调用开始之间有长度为delay的延迟,其中initialDelay为初始延迟。
public ScheduledFuture<?> scheduleWithFixedDelay(Runnable command,
long initialDelay,
long delay,
TimeUnit unit)
实现原理
定时任务队列中就没有非核心线程的概念了,在线程池中都是核心线程,当开始执行任务时,首先把任务放到队列中,然后判断活跃线程数是否小于核心线程数,如果小于就创建线程,如果线程都已经创建满了,就会不断的在队列中取任务,不断的执行。
首先看下scheduleWithFixedDelay()的构造函数,
public ScheduledFuture