Class AsynchronousProcessor<K,V,R>
- java.lang.Object
- 
- com.tangosol.util.AsynchronousAgent<T>
- 
- com.tangosol.util.processor.AbstractAsynchronousProcessor<K,V,R,Map<K,R>>
- 
- com.tangosol.util.processor.AsynchronousProcessor<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<Map<K,R>>
 - Direct Known Subclasses:
- ContinuousQueryCache.ConverterAsynchronousProcessor
 
 public class AsynchronousProcessor<K,V,R> extends AbstractAsynchronousProcessor<K,V,R,Map<K,R>> AnEntryProcessorwrapper class that allows for an asynchronous invocation of the underlying processor. When used as aFuture(without extending), this implementation will collect the results of asynchronous invocation into a Map, providing theresultsemantics identical to theEntryProcessor.processAllcontract.More advanced use would require extending this class and overriding onResult(java.util.Map.Entry<K, R>),onComplete(), andonException(java.lang.Throwable)methods.It is very important that the overriding implementations of these methods must be non-blocking. For example, any use of NamedCacheAPI is completely disallowed, with the only exception of asynchronous agents.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.- Author:
- gg/mf 2012.12.21
- See Also:
- SingleEntryAsynchronousProcessor, Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected Throwablem_eReasonReason for the failed operation.protected List<Map.Entry<K,R>>m_listResultEntriesList of result value entries.- 
Fields inherited from class com.tangosol.util.processor.AbstractAsynchronousProcessorf_processor
 - 
Fields inherited from class com.tangosol.util.AsynchronousAgentm_control, m_iOrderId
 
- 
 - 
Constructor SummaryConstructors Constructor Description AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor)Construct an AsynchronousProcessor for a given processor.AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor, int iUnitOrderId)Construct an AsynchronousProcessor for a given processor.AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor, int iUnitOrderId, Executor executor)Construct an AsynchronousProcessor for a given processor.AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor, Executor executor)Construct an AsynchronousProcessor for a given processor.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidonComplete()Called 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.voidonResult(Map.Entry<K,R> entry)Called when there is a partial result of the asynchronous execution.- 
Methods inherited from class com.tangosol.util.processor.AbstractAsynchronousProcessorgetProcessor, getUnitOfOrderId, process, processAll
 - 
Methods inherited from class com.tangosol.util.AsynchronousAgentbind, cancel, checkBacklog, complete, completeExceptionally, drainBacklog, flush, get, get, getCompletableFuture, getException, getResult, isCancelled, isCompletedExceptionally, isDone
 
- 
 
- 
- 
- 
Field Detail- 
m_eReasonprotected volatile Throwable m_eReason Reason for the failed operation.
 
- 
 - 
Constructor Detail- 
AsynchronousProcessorpublic AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor) Construct an AsynchronousProcessor for a given processor.- Parameters:
- processor- the underlying- InvocableMap.EntryProcessor
 
 - 
AsynchronousProcessorpublic AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor, Executor executor) Construct an AsynchronousProcessor for a given processor.- Parameters:
- processor- the underlying- InvocableMap.EntryProcessor
- executor- an optional- Executorto complete the future on, if not provided the- Daemons.commonPool()is used
 
 - 
AsynchronousProcessorpublic AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor, int iUnitOrderId) Construct an AsynchronousProcessor for a given processor.- Parameters:
- processor- the underlying- InvocableMap.EntryProcessor
- iUnitOrderId- the unit-of-order id for this processor
 
 - 
AsynchronousProcessorpublic AsynchronousProcessor(InvocableMap.EntryProcessor<K,V,R> processor, int iUnitOrderId, Executor executor) Construct an AsynchronousProcessor for a given processor.- Parameters:
- processor- the underlying- InvocableMap.EntryProcessor
- iUnitOrderId- the unit-of-order id for this processor
- executor- an optional- Executorto complete the future on, if not provided the- Daemons.commonPool()is used
 
 
- 
 - 
Method Detail- 
onResultpublic void onResult(Map.Entry<K,R> entry) Description 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. 
 - 
onExceptionpublic void onException(Throwable eReason) Description 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,Map<K,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,Map<K,R>>
 
 
- 
 
-