Class SingleEntryAsynchronousProcessor<K,V,R>  
- Type Parameters:
- K- the type of the Map entry key
- V- the type of the Map entry value
- R- the type of value returned by the EntryProcessor
- All Implemented Interfaces:
- FlowControl,- InvocableMap.EntryProcessor<K,,- V, - R> - Serializable,- Future<R>
EntryProcessor wrapper class that allows for
 an asynchronous invocation of the underlying processor against a single
 cache entry. When used as a Future (without extending), this
 implementation will collect the results of asynchronous invocation,
 providing the result semantics identical to the
 EntryProcessor.process contract.
 
 More advanced use would require extending this class and overriding
 onResult(java.util.Map.Entry<K, R>), onComplete(), and onException(java.lang.Throwable) methods.
 
 It's very important that the overriding implementations of these methods
 must be non-blocking. For example, any use of NamedCache API is
 completely disallowed, with the only exception of asynchronous agents
 with disabled flow control.
 
 The underlying entry processor is guaranteed to have been fully executed when
 onComplete() is called.
 
 Note 1: Neither this class nor its extensions need to be serializable. Only the
 underlying processor is serialized and sent to corresponding servers for execution.
 
 Note 2: This feature is not available on Coherence*Extend clients.
- Since:
- 12.2.1
- Author:
- as 2015.01.26
- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from interface java.util.concurrent.FutureFuture.State
- 
Field SummaryFieldsModifier and TypeFieldDescriptionThe result of entry processor invocation.protected ThrowableReason for the failed operation.Fields inherited from class com.tangosol.util.processor.AbstractAsynchronousProcessorf_processorFields inherited from class com.tangosol.util.AsynchronousAgentm_control, m_iOrderId
- 
Constructor SummaryConstructorsConstructorDescriptionSingleEntryAsynchronousProcessor(InvocableMap.EntryProcessor<K, V, R> processor) Construct a SingleEntryAsynchronousProcessor for a given processor.SingleEntryAsynchronousProcessor(InvocableMap.EntryProcessor<K, V, R> processor, int iUnitOrderId) Construct a SingleEntryAsynchronousProcessor for a given processor.
- 
Method SummaryModifier and TypeMethodDescriptionvoidCalled after the processor has been notified about all possible partial results or failures and no more are forthcoming.voidonException(Throwable eReason) Called if any part of the operation failed for any reason.voidCalled when there is a partial result of the asynchronous execution.Methods inherited from class com.tangosol.util.processor.AbstractAsynchronousProcessorgetProcessor, getUnitOfOrderId, process, processAllMethods inherited from class com.tangosol.util.AsynchronousAgentbind, cancel, checkBacklog, complete, completeExceptionally, drainBacklog, flush, get, get, getCompletableFuture, getException, getResult, isCancelled, isCompletedExceptionally, isDoneMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.util.concurrent.FutureexceptionNow, resultNow, state
- 
Field Details- 
m_eReasonReason for the failed operation.
- 
m_entryThe result of entry processor invocation.
 
- 
- 
Constructor Details- 
SingleEntryAsynchronousProcessorConstruct a SingleEntryAsynchronousProcessor for a given processor.- Parameters:
- processor- the underlying- InvocableMap.EntryProcessor
 
- 
SingleEntryAsynchronousProcessorpublic SingleEntryAsynchronousProcessor(InvocableMap.EntryProcessor<K, V, R> processor, int iUnitOrderId) Construct a SingleEntryAsynchronousProcessor for a given processor.- Parameters:
- processor- the underlying- InvocableMap.EntryProcessor
- iUnitOrderId- the unit-of-order id for this processor
 
 
- 
- 
Method Details- 
onResultDescription copied from class:AbstractAsynchronousProcessorCalled when there is a partial result of the asynchronous execution.For a given request, calls to this method and AbstractAsynchronousProcessor.onException(java.lang.Throwable)may come concurrently.For ordering guarantees across different processor invocations see AbstractAsynchronousProcessor.getUnitOfOrderId().Note: Overriding implementations of this method must be non-blocking. 
- 
onExceptionDescription copied from class:AbstractAsynchronousProcessorCalled if any part of the operation failed for any reason. For operations that span multiple partitions this method could be called more than once. However, unless subclasses override this method, any failure will"complete"the operation.Note: Overriding implementations of this method must be non-blocking. - Specified by:
- onExceptionin class- AbstractAsynchronousProcessor<K,- V, - R, - R> 
- Parameters:
- eReason- the reason of failure
 
- 
onCompletepublic void onComplete()Description copied from class:AbstractAsynchronousProcessorCalled after the processor has been notified about all possible partial results or failures and no more are forthcoming. As long as this processor was submitted to any ofInvocableMap's methods, this method is guaranteed to be called once and only once.Possible call back sequences are: cache.invoke ... onResult onComplete cache.invoke ... onException onComplete cache.invokeAll ... onResult onException onException onResult onCompleteFor ordering guarantees across processors seeAbstractAsynchronousProcessor.getUnitOfOrderId().Note: Overriding implementations of this method must be non-blocking. - Specified by:
- onCompletein class- AbstractAsynchronousProcessor<K,- V, - R, - R> 
 
 
-