Package io.servicetalk.concurrent
Interface Executor
-
- All Known Subinterfaces:
Executor
- All Known Implementing Classes:
DelegatingExecutor
,OffloaderAwareExecutor
,TestExecutor
public interface Executor
A general abstraction to execute immediate and delayed tasks.Long running tasks
Executor
implementations are expected to run long running (blocking) tasks which may depend on other tasks submitted to the sameExecutor
instance. In order to avoid deadlocks, it is generally a good idea to not allow task queuing in theExecutor
.
-
-
Method Summary
All Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description Cancellable
execute(java.lang.Runnable task)
Executes the passedtask
as soon as possible.Cancellable
schedule(java.lang.Runnable task, long delay, java.util.concurrent.TimeUnit unit)
Executes the passedtask
afterdelay
amount ofunit
s time has passed.default Cancellable
schedule(java.lang.Runnable task, java.time.Duration delay)
Executes the passedtask
afterdelay
amount time has passed.
-
-
-
Method Detail
-
execute
Cancellable execute(java.lang.Runnable task) throws java.util.concurrent.RejectedExecutionException
Executes the passedtask
as soon as possible.- Parameters:
task
- to execute.- Returns:
Cancellable
to cancel the task if not yet executed.- Throws:
java.util.concurrent.RejectedExecutionException
- If the task is rejected.
-
schedule
Cancellable schedule(java.lang.Runnable task, long delay, java.util.concurrent.TimeUnit unit) throws java.util.concurrent.RejectedExecutionException
Executes the passedtask
afterdelay
amount ofunit
s time has passed.Note this method is not guaranteed to provide real time execution. For example implementations are free to consolidate tasks into time buckets to reduce the overhead of timer management at the cost of reduced timer fidelity.
- Parameters:
task
- to execute.delay
- The time duration that is allowed to elapse beforetask
is executed.unit
- The units fordelay
.- Returns:
Cancellable
to cancel the task if not yet executed.- Throws:
java.util.concurrent.RejectedExecutionException
- If the task is rejected.
-
schedule
default Cancellable schedule(java.lang.Runnable task, java.time.Duration delay) throws java.util.concurrent.RejectedExecutionException
Executes the passedtask
afterdelay
amount time has passed.Note this method is not guaranteed to provide real time execution. For example implementations are free to consolidate tasks into time buckets to reduce the overhead of timer management at the cost of reduced timer fidelity.
- Parameters:
task
- to execute.delay
- The time duration that is allowed to elapse beforetask
is executed.- Returns:
Cancellable
to cancel the task if not yet executed.- Throws:
java.util.concurrent.RejectedExecutionException
- If the task is rejected.
-
-