V - The result type returned by this Future's get methodpublic abstract class AbstractCompletableFuture<V> extends Object implements ICompletableFuture<V>
ICompletableFuture implementation that may be explicitly completed by setting its
 value through setResult.
 Implements the logic of cancellation and callbacks execution.| Modifier | Constructor and Description | 
|---|---|
| protected  | AbstractCompletableFuture(Executor defaultExecutor,
                         ILogger logger) | 
| protected  | AbstractCompletableFuture(NodeEngine nodeEngine,
                         ILogger logger) | 
| Modifier and Type | Method and Description | 
|---|---|
| void | andThen(ExecutionCallback<V> callback)Registers a callback that will run after this future is completed. | 
| void | andThen(ExecutionCallback<V> callback,
       Executor executor)Registers a callback that will run with the provided executor after this
 future is completed. | 
| boolean | cancel(boolean mayInterruptIfRunning) | 
| protected void | cancelled(boolean mayInterruptIfRunning)Protected method invoked when this task transitions to state
  isCancelled. | 
| protected void | done()Protected method invoked when this task transitions to state
  isDone(only normally - in case of cancellation cancelled() is invoked)
 The default implementation does nothing. | 
| V | get() | 
| V | get(long timeout,
   TimeUnit unit)PLEASE NOTE: It's legal to override this method, but please bear in mind that you should call super.get() or
 implement the done() and cancelled() callbacks to be notified if this future gets done or cancelled. | 
| protected V | getResult()Returns:
 
 null - if cancelled or not done
 result - if done and result is NOT Throwable
 sneaky throws an exception - if done and result is Throwable
  | 
| boolean | isCancelled() | 
| boolean | isDone() | 
| protected boolean | setResult(Object result)Sets the result. | 
| protected boolean | shouldCancel(boolean mayInterruptIfRunning)Protected method invoked on cancel(). | 
protected AbstractCompletableFuture(NodeEngine nodeEngine, ILogger logger)
public void andThen(ExecutionCallback<V> callback)
ICompletableFuturePlease note that there is no ordering guarantee for running multiple callbacks. It is also not guaranteed that the callback will run within the same thread that completes the future.
andThen in interface ICompletableFuture<V>callback - the callback to executepublic void andThen(ExecutionCallback<V> callback, Executor executor)
ICompletableFutureexecutor.
 Please note that there is no ordering guarantee for executing multiple
 callbacks.andThen in interface ICompletableFuture<V>callback - the callback to executeexecutor - the executor in which the callback will be runpublic final boolean cancel(boolean mayInterruptIfRunning)
protected boolean shouldCancel(boolean mayInterruptIfRunning)
mayInterruptIfRunning - passed through from cancel callprotected void cancelled(boolean mayInterruptIfRunning)
isCancelled. The default implementation does nothing.
 Subclasses may override this method to invoke callbacks or perform
 bookkeeping. Implementation has to handle exceptions itself.mayInterruptIfRunning - true if the thread executing this
                              task was supposed to be interrupted; otherwise, in-progress tasks are allowed
                              to completepublic boolean isCancelled()
isCancelled in interface Future<V>public final V get() throws InterruptedException, ExecutionException
get in interface Future<V>InterruptedExceptionExecutionExceptionpublic V get(long timeout, TimeUnit unit) throws ExecutionException, InterruptedException, TimeoutException
get in interface Future<V>ExecutionExceptionInterruptedExceptionTimeoutExceptionprotected boolean setResult(Object result)
result is an instance of Throwable, this
 future will be completed exceptionally. That is, get() will throw
 the exception rather than return it.protected void done()
isDone (only normally - in case of cancellation cancelled() is invoked)
 The default implementation does nothing.
 Subclasses may override this method to invoke callbacks or perform
 bookkeeping. Implementation has to handle exceptions itself.protected V getResult()
Copyright © 2020 Hazelcast, Inc.. All Rights Reserved.