public interface ManagedScheduledExecutorService extends ManagedExecutorService, ScheduledExecutorService
ScheduledExecutorService.
 A ManagedScheduledExecutorService extends the Java™ SE ScheduledExecutorService
 to provide methods for submitting delayed or periodic tasks for execution in
 a Jakarta™ EE environment.
 Implementations of the ManagedScheduledExecutorService are
 provided by a Jakarta EE Product Provider.  Application Component Providers
 use the Java Naming and Directory Interface™ (JNDI) to look-up instances of one
 or more ManagedScheduledExecutorService objects using resource environment references.
 ManagedScheduledExecutorService instances can also be injected into application
 components through the use of the Resource annotation.
The Jakarta Concurrency specification describes several behaviors that a ManagedScheduledExecutorService can implement. The Application Component Provider and Deployer identify these requirements and map the resource environment reference appropriately.
 Tasks are run in managed threads provided by the Jakarta™ EE Product Provider
 and are run within the application component context that submitted the task.
 All tasks run without an explicit transaction (they do not enlist in the application
 component's transaction).  If a transaction is required, use a
 javax.transaction.UserTransaction instance.  A UserTransaction instance is
 available in JNDI using the name: "java:comp/UserTransaction" or by
 requesting an injection of a UserTransaction object
 using the Resource annotation.
Example:
 public run() {
   // Begin of task
   InitialContext ctx = new InitialContext();
   UserTransaction ut = (UserTransaction) ctx.lookup("java:comp/UserTransaction");
   ut.begin();
   // Perform transactional business logic
   ut.commit();
 }
 
 Tasks can optionally provide an ManagedTaskListener to receive 
 notifications of lifecycle events, through the use of ManagedTask
 interface.
 
 Asynchronous tasks are typically submitted to the ManagedScheduledExecutorService using one
 of the submit or schedulemethods, each of which return a Future
 instance.  The Future represents the result of the task and can also be used to
 check if the task is complete or wait for its completion.
 If the task is cancelled, the result for the task is a
 CancellationException exception.  If the task is unable
 to run due to start due to a reason other than cancellation, the result is a
 AbortedException exception.  If the task is scheduled
 with a Trigger and the Trigger forces the task to be skipped,
 the result will be a SkippedException exception.
 Tasks can be scheduled to run periodically using the schedule methods that
 take a Trigger as an argument and the scheduleAtFixedRate and
 scheduleWithFixedDelay methods.  The result of the Future will
 be represented by the currently scheduled or running instance of the task.  Future and past executions
 of the task are not represented by the Future.  The state of the Future will therefore change
 and multiple results are expected.
 For example, if a task is repeating, the lifecycle of the task would be:
 (Note:  See ManagedTaskListener for task lifecycle management details.)
| Sequence | State | Action | Listener | Next state | 
| 1A. | None | submit() | taskSubmitted | Submitted | 
| 2A. | Submitted | About to call run() | taskStarting | Started | 
| 3A. | Started | Exit run() | taskDone | Reschedule | 
| 1B. | Reschedule | taskSubmitted | Submitted | |
| 2B. | Submitted | About to call run() | taskStarting | Started | 
| 3B. | Started | Exit run() | taskDone | Reschedule | 
| Modifier and Type | Method and Description | 
|---|---|
| <V> ScheduledFuture<V> | schedule(Callable<V> callable,
        Trigger trigger)Creates and executes a task based on a Trigger. | 
| ScheduledFuture<?> | schedule(Runnable command,
        Trigger trigger)Creates and executes a task based on a Trigger. | 
schedule, schedule, scheduleAtFixedRate, scheduleWithFixedDelayawaitTermination, invokeAll, invokeAll, invokeAny, invokeAny, isShutdown, isTerminated, shutdown, shutdownNow, submit, submit, submitScheduledFuture<?> schedule(Runnable command, Trigger trigger)
command - the task to execute.trigger - the trigger that determines when the task should fire.get() 
         method will return null upon completion.RejectedExecutionException - if task cannot be scheduled for execution.NullPointerException - if command is null.<V> ScheduledFuture<V> schedule(Callable<V> callable, Trigger trigger)
callable - the function to execute.trigger - the trigger that determines when the task should fire.RejectedExecutionException - if task cannot be scheduled for execution.NullPointerException - if callable is null.Copyright © 2019 Eclipse Foundation.
Use is subject to license terms.