public class ThreadPoolTaskScheduler extends ExecutorConfigurationSupport implements org.springframework.core.task.AsyncListenableTaskExecutor, SchedulingTaskExecutor, TaskScheduler
TaskScheduler interface, wrapping
 a native ScheduledThreadPoolExecutor.setPoolSize(int), 
setRemoveOnCancelPolicy(boolean), 
ExecutorConfigurationSupport.setThreadFactory(java.util.concurrent.ThreadFactory), 
setErrorHandler(org.springframework.util.ErrorHandler), 
Serialized Formlogger| Constructor and Description | 
|---|
| ThreadPoolTaskScheduler() | 
| Modifier and Type | Method and Description | 
|---|---|
| protected ScheduledExecutorService | createExecutor(int poolSize,
              ThreadFactory threadFactory,
              RejectedExecutionHandler rejectedExecutionHandler)Create a new  ScheduledExecutorServiceinstance. | 
| void | execute(Runnable task) | 
| void | execute(Runnable task,
       long startTimeout) | 
| int | getActiveCount()Return the number of currently active threads. | 
| int | getPoolSize()Return the current pool size. | 
| ScheduledExecutorService | getScheduledExecutor()Return the underlying ScheduledExecutorService for native access. | 
| ScheduledThreadPoolExecutor | getScheduledThreadPoolExecutor()Return the underlying ScheduledThreadPoolExecutor, if available. | 
| protected ExecutorService | initializeExecutor(ThreadFactory threadFactory,
                  RejectedExecutionHandler rejectedExecutionHandler)Create the target  ExecutorServiceinstance. | 
| boolean | isRemoveOnCancelPolicy()Return the current setting for the remove-on-cancel mode. | 
| boolean | prefersShortLivedTasks()Does this  TaskExecutorprefer short-lived tasks over
 long-lived tasks? | 
| ScheduledFuture<?> | schedule(Runnable task,
        Date startTime)Schedule the given  Runnable, invoking it at the specified execution time. | 
| ScheduledFuture<?> | schedule(Runnable task,
        Trigger trigger)Schedule the given  Runnable, invoking it whenever the trigger
 indicates a next execution time. | 
| ScheduledFuture<?> | scheduleAtFixedRate(Runnable task,
                   Date startTime,
                   long period)Schedule the given  Runnable, invoking it at the specified execution time
 and subsequently with the given period. | 
| ScheduledFuture<?> | scheduleAtFixedRate(Runnable task,
                   long period)Schedule the given  Runnable, starting as soon as possible and
 invoking it with the given period. | 
| ScheduledFuture<?> | scheduleWithFixedDelay(Runnable task,
                      Date startTime,
                      long delay)Schedule the given  Runnable, invoking it at the specified execution time
 and subsequently with the given delay between the completion of one execution
 and the start of the next. | 
| ScheduledFuture<?> | scheduleWithFixedDelay(Runnable task,
                      long delay)Schedule the given  Runnable, starting as soon as possible and
 invoking it with the given delay between the completion of one execution
 and the start of the next. | 
| void | setErrorHandler(org.springframework.util.ErrorHandler errorHandler)Set a custom  ErrorHandlerstrategy. | 
| void | setPoolSize(int poolSize)Set the ScheduledExecutorService's pool size. | 
| void | setRemoveOnCancelPolicy(boolean removeOnCancelPolicy)Set the remove-on-cancel mode on  ScheduledThreadPoolExecutor(JDK 7+). | 
| <T> Future<T> | submit(Callable<T> task) | 
| Future<?> | submit(Runnable task) | 
| <T> org.springframework.util.concurrent.ListenableFuture<T> | submitListenable(Callable<T> task) | 
| org.springframework.util.concurrent.ListenableFuture<?> | submitListenable(Runnable task) | 
afterPropertiesSet, destroy, initialize, setAwaitTerminationSeconds, setBeanName, setRejectedExecutionHandler, setThreadFactory, setThreadNamePrefix, setWaitForTasksToCompleteOnShutdown, shutdownnewThreadpublic void setPoolSize(int poolSize)
This setting can be modified at runtime, for example through JMX.
@UsesJava7 public void setRemoveOnCancelPolicy(boolean removeOnCancelPolicy)
ScheduledThreadPoolExecutor (JDK 7+).
 Default is false. If set to true, the target executor will be
 switched into remove-on-cancel mode (if possible, with a soft fallback otherwise).
 
This setting can be modified at runtime, for example through JMX.
public void setErrorHandler(org.springframework.util.ErrorHandler errorHandler)
ErrorHandler strategy.@UsesJava7 protected ExecutorService initializeExecutor(ThreadFactory threadFactory, RejectedExecutionHandler rejectedExecutionHandler)
ExecutorConfigurationSupportExecutorService instance.
 Called by afterPropertiesSet.initializeExecutor in class ExecutorConfigurationSupportthreadFactory - the ThreadFactory to userejectedExecutionHandler - the RejectedExecutionHandler to useExecutorConfigurationSupport.afterPropertiesSet()protected ScheduledExecutorService createExecutor(int poolSize, ThreadFactory threadFactory, RejectedExecutionHandler rejectedExecutionHandler)
ScheduledExecutorService instance.
 The default implementation creates a ScheduledThreadPoolExecutor.
 Can be overridden in subclasses to provide custom ScheduledExecutorService instances.
poolSize - the specified pool sizethreadFactory - the ThreadFactory to userejectedExecutionHandler - the RejectedExecutionHandler to useExecutorConfigurationSupport.afterPropertiesSet(), 
ScheduledThreadPoolExecutorpublic ScheduledExecutorService getScheduledExecutor() throws IllegalStateException
null)IllegalStateException - if the ThreadPoolTaskScheduler hasn't been initialized yetpublic ScheduledThreadPoolExecutor getScheduledThreadPoolExecutor() throws IllegalStateException
null)IllegalStateException - if the ThreadPoolTaskScheduler hasn't been initialized yet
 or if the underlying ScheduledExecutorService isn't a ScheduledThreadPoolExecutorgetScheduledExecutor()public int getPoolSize()
Requires an underlying ScheduledThreadPoolExecutor.
@UsesJava7 public boolean isRemoveOnCancelPolicy()
Requires an underlying ScheduledThreadPoolExecutor.
public int getActiveCount()
Requires an underlying ScheduledThreadPoolExecutor.
public void execute(Runnable task)
public void execute(Runnable task, long startTimeout)
execute in interface org.springframework.core.task.AsyncTaskExecutorpublic Future<?> submit(Runnable task)
submit in interface org.springframework.core.task.AsyncTaskExecutorpublic <T> Future<T> submit(Callable<T> task)
submit in interface org.springframework.core.task.AsyncTaskExecutorpublic org.springframework.util.concurrent.ListenableFuture<?> submitListenable(Runnable task)
submitListenable in interface org.springframework.core.task.AsyncListenableTaskExecutorpublic <T> org.springframework.util.concurrent.ListenableFuture<T> submitListenable(Callable<T> task)
submitListenable in interface org.springframework.core.task.AsyncListenableTaskExecutorpublic boolean prefersShortLivedTasks()
SchedulingTaskExecutorTaskExecutor prefer short-lived tasks over
 long-lived tasks?
 A SchedulingTaskExecutor implementation can indicate
 whether it prefers submitted tasks to perform as little work as they
 can within a single task execution. For example, submitted tasks
 might break a repeated loop into individual subtasks which submit a
 follow-up task afterwards (if feasible).
 
This should be considered a hint. Of course TaskExecutor
 clients are free to ignore this flag and hence the
 SchedulingTaskExecutor interface overall. However, thread
 pools will usually indicated a preference for short-lived tasks, to be
 able to perform more fine-grained scheduling.
prefersShortLivedTasks in interface SchedulingTaskExecutortrue if this TaskExecutor prefers
 short-lived taskspublic ScheduledFuture<?> schedule(Runnable task, Trigger trigger)
TaskSchedulerRunnable, invoking it whenever the trigger
 indicates a next execution time.
 Execution will end once the scheduler shuts down or the returned
 ScheduledFuture gets cancelled.
schedule in interface TaskSchedulertask - the Runnable to execute whenever the trigger firestrigger - an implementation of the Trigger interface,
 e.g. a CronTrigger object
 wrapping a cron expressionScheduledFuture representing pending completion of the task,
 or null if the given Trigger object never fires (i.e. returns
 null from Trigger.nextExecutionTime(org.springframework.scheduling.TriggerContext))CronTriggerpublic ScheduledFuture<?> schedule(Runnable task, Date startTime)
TaskSchedulerRunnable, invoking it at the specified execution time.
 Execution will end once the scheduler shuts down or the returned
 ScheduledFuture gets cancelled.
schedule in interface TaskSchedulertask - the Runnable to execute whenever the trigger firesstartTime - the desired execution time for the task
 (if this is in the past, the task will be executed immediately, i.e. as soon as possible)ScheduledFuture representing pending completion of the taskpublic ScheduledFuture<?> scheduleAtFixedRate(Runnable task, Date startTime, long period)
TaskSchedulerRunnable, invoking it at the specified execution time
 and subsequently with the given period.
 Execution will end once the scheduler shuts down or the returned
 ScheduledFuture gets cancelled.
scheduleAtFixedRate in interface TaskSchedulertask - the Runnable to execute whenever the trigger firesstartTime - the desired first execution time for the task
 (if this is in the past, the task will be executed immediately, i.e. as soon as possible)period - the interval between successive executions of the task (in milliseconds)ScheduledFuture representing pending completion of the taskpublic ScheduledFuture<?> scheduleAtFixedRate(Runnable task, long period)
TaskSchedulerRunnable, starting as soon as possible and
 invoking it with the given period.
 Execution will end once the scheduler shuts down or the returned
 ScheduledFuture gets cancelled.
scheduleAtFixedRate in interface TaskSchedulertask - the Runnable to execute whenever the trigger firesperiod - the interval between successive executions of the task (in milliseconds)ScheduledFuture representing pending completion of the taskpublic ScheduledFuture<?> scheduleWithFixedDelay(Runnable task, Date startTime, long delay)
TaskSchedulerRunnable, invoking it at the specified execution time
 and subsequently with the given delay between the completion of one execution
 and the start of the next.
 Execution will end once the scheduler shuts down or the returned
 ScheduledFuture gets cancelled.
scheduleWithFixedDelay in interface TaskSchedulertask - the Runnable to execute whenever the trigger firesstartTime - the desired first execution time for the task
 (if this is in the past, the task will be executed immediately, i.e. as soon as possible)delay - the delay between the completion of one execution and the start
 of the next (in milliseconds)ScheduledFuture representing pending completion of the taskpublic ScheduledFuture<?> scheduleWithFixedDelay(Runnable task, long delay)
TaskSchedulerRunnable, starting as soon as possible and
 invoking it with the given delay between the completion of one execution
 and the start of the next.
 Execution will end once the scheduler shuts down or the returned
 ScheduledFuture gets cancelled.
scheduleWithFixedDelay in interface TaskSchedulertask - the Runnable to execute whenever the trigger firesdelay - the interval between successive executions of the task (in milliseconds)ScheduledFuture representing pending completion of the task