public abstract class Offload extends CallStatus
Offloadable.
 The Offload is a CallStatus designed when an offloaded operation
 needs to offload the processing of the operation to a different system, e.g
 a different thread and at some point in the future a response will be ready.
 Offload instance can be created by Operations that require offloading, for
 more information see the Operation.call().
 If the operation 'offloads' some work, but doesn't send a response ever,
 CallStatus.DONE_VOID should be used instead.
 init(NodeEngineImpl, Set) is called, the original
 OperationResponseHandler of the offloaded operation is decorated with
 one of designed for the offloading (see heartbeats for more info). This means
 that sending a response for an offloaded operation, can be done using the
 regular response handling mechanism
 (see Operation.sendResponse(Object) or
 Operation.getOperationResponseHandler(). But one should not modify
 the response handler of an offloaded Operation because otherwise one could
 e.g. run into a memory leak (the offloaded operation will not be removed
 from the asynchronous operations).
 There is an important difference with exception handling. With regular
 operation when an exception is thrown, first the
 Operation.onExecutionFailure(Throwable) is called before the
 Operation.sendResponse(Object) is called. But with an offloaded
 operation, typically the Operation.sendResponse(Object) is called by
 the implementation of the offloading logic. So if you need the
 Operation.onExecutionFailure(Throwable) to be executed, just as the
 sendResponse call, the onExecuteFailure call is your own concern.
 init(NodeEngineImpl, Set) is called. And it is unregistered,
 as soon as a response is send to the offloaded operation. This is done by
 decorating updating the original response handler of the operation by wrapping
 it in a decorating response handler that automatically deregisters on completion.| Modifier and Type | Field and Description | 
|---|---|
| protected ExecutionService | executionService | 
| protected NodeEngine | nodeEngine | 
| protected InternalOperationService | operationService | 
| protected SerializationService | serializationService | 
DONE_RESPONSE, DONE_RESPONSE_ORDINAL, DONE_VOID, DONE_VOID_ORDINAL, OFFLOAD_ORDINAL, WAIT, WAIT_ORDINAL| Constructor and Description | 
|---|
| Offload(Operation offloadedOperation)Creates a new Offload instance. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | init(NodeEngineImpl nodeEngine,
    Set<Operation> asyncOperations)Initializes the Offload. | 
| Operation | offloadedOperation()Returns the Operation that created this Offload. | 
| abstract void | start()Starts the actual offloading. | 
ordinalprotected InternalOperationService operationService
protected NodeEngine nodeEngine
protected ExecutionService executionService
protected SerializationService serializationService
public Offload(Operation offloadedOperation)
offloadedOperation - the Operation that is offloadedpublic final Operation offloadedOperation()
public final void init(NodeEngineImpl nodeEngine, Set<Operation> asyncOperations)
OperationResponseHandler of
 the offloaded Operation is replaced by a decorated version that
 takes care of automatic deregistration of the operation on completion.
 This method is called before the start() is called by the
 Operation infrastructure. An implementor of the Offload doesn't
 need to deal with this method.nodeEngine - the NodeEngineImplpublic abstract void start()
                    throws Exception
Operation.call() where this Offload instance was returned. So in
 most cases you want to schedule some work and then return from this method ASAP so
 that the thread is released.
 This method is called after the Operation.afterRun() is called.
 It is allowed to call Operation.sendResponse(Object) in the start
 method if there is nothing to offload.Exception - if something fails. If this happens, regular Operation
                   exception handling is triggered and normally the
                   exception is returned to the caller.Copyright © 2019 Hazelcast, Inc.. All Rights Reserved.