Package io.servicetalk.concurrent
Interface Executor
- All Superinterfaces:
TimeSource
- All Known Subinterfaces:
EventLoopAwareNettyIoExecutor
,Executor
,IoExecutor
,NettyIoExecutor
- All Known Implementing Classes:
DelegatingExecutor
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 same Executor
instance.
In order to avoid deadlocks, it is generally a good idea to not allow task queuing in the Executor
.-
Method Summary
Modifier and TypeMethodDescriptiondefault long
currentTime
(TimeUnit unit) Returns the internal clock time in the specifiedunit
.Executes the passedtask
as soon as possible.Executes the passedtask
afterdelay
amount ofunit
s time has passed.default Cancellable
Executes the passedtask
afterdelay
amount time has passed.
-
Method Details
-
currentTime
Description copied from interface:TimeSource
Returns the internal clock time in the specifiedunit
.- Specified by:
currentTime
in interfaceTimeSource
- Parameters:
unit
- the time unit to calculate- Returns:
- the internal clock time in the specified
unit
.
-
execute
Executes the passedtask
as soon as possible.- Parameters:
task
- to execute.- Returns:
Cancellable
to cancel the task if not yet executed.- Throws:
RejectedExecutionException
- If the task is rejected.
-
schedule
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:
RejectedExecutionException
- If the task is rejected.
-
schedule
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:
RejectedExecutionException
- If the task is rejected.
-