public class ScheduledExecutorTask
extends java.lang.Object
Runnable and a delay plus period. The period needs to be specified;
 there is no point in a default for it.
 The ScheduledExecutorService does not offer
 more sophisticated scheduling options such as cron expressions.
 Consider using ThreadPoolTaskScheduler for such needs.
 
Note that the ScheduledExecutorService mechanism
 uses a Runnable instance that is shared between repeated executions,
 in contrast to Quartz which creates a new Job instance for each execution.
ScheduledExecutorService.scheduleWithFixedDelay(java.lang.Runnable, long, long, java.util.concurrent.TimeUnit), 
ScheduledExecutorService.scheduleAtFixedRate(java.lang.Runnable, long, long, java.util.concurrent.TimeUnit)| Constructor and Description | 
|---|
| ScheduledExecutorTask()Create a new ScheduledExecutorTask,
 to be populated via bean properties. | 
| ScheduledExecutorTask(java.lang.Runnable executorTask)Create a new ScheduledExecutorTask, with default
 one-time execution without delay. | 
| ScheduledExecutorTask(java.lang.Runnable executorTask,
                     long delay)Create a new ScheduledExecutorTask, with default
 one-time execution with the given delay. | 
| ScheduledExecutorTask(java.lang.Runnable executorTask,
                     long delay,
                     long period,
                     boolean fixedRate)Create a new ScheduledExecutorTask. | 
| Modifier and Type | Method and Description | 
|---|---|
| long | getDelay()Return the delay before starting the job for the first time. | 
| long | getPeriod()Return the period between repeated task executions. | 
| java.lang.Runnable | getRunnable()Return the Runnable to schedule as executor task. | 
| java.util.concurrent.TimeUnit | getTimeUnit()Return the time unit for the delay and period values. | 
| boolean | isFixedRate()Return whether to schedule as fixed-rate execution. | 
| boolean | isOneTimeTask()Is this task only ever going to execute once? | 
| void | setDelay(long delay)Set the delay before starting the task for the first time,
 in milliseconds. | 
| void | setFixedRate(boolean fixedRate)Set whether to schedule as fixed-rate execution, rather than
 fixed-delay execution. | 
| void | setPeriod(long period)Set the period between repeated task executions, in milliseconds. | 
| void | setRunnable(java.lang.Runnable executorTask)Set the Runnable to schedule as executor task. | 
| void | setTimeUnit(java.util.concurrent.TimeUnit timeUnit)Specify the time unit for the delay and period values. | 
public ScheduledExecutorTask()
setDelay(long), 
setPeriod(long), 
setFixedRate(boolean)public ScheduledExecutorTask(java.lang.Runnable executorTask)
executorTask - the Runnable to schedulepublic ScheduledExecutorTask(java.lang.Runnable executorTask,
                             long delay)
executorTask - the Runnable to scheduledelay - the delay before starting the task for the first time (ms)public ScheduledExecutorTask(java.lang.Runnable executorTask,
                             long delay,
                             long period,
                             boolean fixedRate)
executorTask - the Runnable to scheduledelay - the delay before starting the task for the first time (ms)period - the period between repeated task executions (ms)fixedRate - whether to schedule as fixed-rate executionpublic void setRunnable(java.lang.Runnable executorTask)
public java.lang.Runnable getRunnable()
public void setDelay(long delay)
public long getDelay()
public void setPeriod(long period)
Default is -1, leading to one-time execution. In case of a positive value, the task will be executed repeatedly, with the given interval in-between executions.
Note that the semantics of the period value vary between fixed-rate and fixed-delay execution.
Note: A period of 0 (for example as fixed delay) is not supported,
 simply because java.util.concurrent.ScheduledExecutorService itself
 does not support it. Hence a value of 0 will be treated as one-time execution;
 however, that value should never be specified explicitly in the first place!
setFixedRate(boolean), 
isOneTimeTask(), 
ScheduledExecutorService.scheduleWithFixedDelay(Runnable, long, long, java.util.concurrent.TimeUnit)public long getPeriod()
public boolean isOneTimeTask()
true if this task is only ever going to execute oncegetPeriod()public void setTimeUnit(java.util.concurrent.TimeUnit timeUnit)
TimeUnit.MILLISECONDS).TimeUnit.MILLISECONDS, 
TimeUnit.SECONDSpublic java.util.concurrent.TimeUnit getTimeUnit()
public void setFixedRate(boolean fixedRate)
See ScheduledExecutorService javadoc for details on those execution modes.
ScheduledExecutorService.scheduleWithFixedDelay(java.lang.Runnable, long, long, java.util.concurrent.TimeUnit), 
ScheduledExecutorService.scheduleAtFixedRate(java.lang.Runnable, long, long, java.util.concurrent.TimeUnit)public boolean isFixedRate()