All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.tangosol.util.processor.AbstractAsynchronousProcessor Maven / Gradle / Ivy

There is a newer version: 24.09
Show newest version
/*
 * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
 *
 * Licensed under the Universal Permissive License v 1.0 as shown at
 * http://oss.oracle.com/licenses/upl.
 */
package com.tangosol.util.processor;


import com.tangosol.util.AsynchronousAgent;
import com.tangosol.util.InvocableMap;

import com.tangosol.util.aggregator.AsynchronousAggregator;

import java.util.Map;
import java.util.Set;


/**
 * Abstract base class for asynchronous entry processors.
 *
 * @param   the type of the Map entry key
 * @param   the type of the Map entry value
 * @param   the type of value returned by the EntryProcessor
 * @param   the type of the result
 *
 * @author as  2015.01.26
 * @since 12.2.1
 */
public abstract class AbstractAsynchronousProcessor
        extends AsynchronousAgent
        implements InvocableMap.EntryProcessor
    {
    // ---- constructors ----------------------------------------------------

    /**
     * Construct AbstractAsynchronousProcessor instance.
     *
     * @param processor     the underlying {@link InvocableMap.EntryProcessor}
     * @param iUnitOrderId  the unit-of-order id for this processor
     */
    protected AbstractAsynchronousProcessor(InvocableMap.EntryProcessor processor,
                                 int iUnitOrderId)
        {
        super(iUnitOrderId);

        f_processor = processor;
        }

    // ---- AbstractAsynchronousProcessor API --------------------------------

    /**
     * Called when there is a partial result of the asynchronous execution.
     * 

* For a given request, calls to this method and {@link #onException} * may come concurrently. *

* For ordering guarantees across different processor invocations see * {@link #getUnitOfOrderId}. *

* Note: Overriding implementations of this method must be non-blocking. * * @param entry an entry holding the key and a result of the operation for * the given key */ public abstract void onResult(Map.Entry entry); /** * Called 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 of {@link InvocableMap}'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
     *     onComplete
     * 
* * For ordering guarantees across processors see {@link #getUnitOfOrderId}. *

* Note: Overriding implementations of this method must be non-blocking. */ public abstract void onComplete(); /** * Called 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 * {@link #isDone() "complete"} the operation. *

* Note: Overriding implementations of this method must be non-blocking. * * @param eReason the reason of failure */ public abstract void onException(Throwable eReason); // ---- accessors ------------------------------------------------------- /** * Return a unit-of-order id associated with this processor. By default, * the unit-of-order id is assigned to the calling thread's hashCode. *

* If two consecutive "invoke" calls are made using {@link AsynchronousProcessor * AsynchronousProcessors} with the same order id and the same key set, * then the corresponding {@link InvocableMap.EntryProcessor#process execution} and calls * to {@link #onResult} are going to happen in the exact same order. *

* If two consecutive "invoke" calls are made using {@link AsynchronousProcessor * AsynchronousProcessors} with the same order id and the same partition set, * then the the corresponding {@link InvocableMap.EntryProcessor#process execution} and * calls to {@link #onComplete} are going to happen in the exact same order. *

* Note 1: The ordering guarantee is respected between {@link AsynchronousProcessor * AsynchronousProcessors} and {@link AsynchronousAggregator}s with the same * unit-of-order id. *
* Note 2: There is no ordering guarantees between asynchronous and synchronous * operations. * * @return the unit-of-order id associated with this processor */ public int getUnitOfOrderId() { return m_iOrderId; } /** * Obtain the underlying entry processor. * * @return the underlying entry processor */ public InvocableMap.EntryProcessor getProcessor() { return f_processor; } // ---- EntryProcessor interface ---------------------------------------- /** * Not supported. */ public R process(InvocableMap.Entry entry) { throw new UnsupportedOperationException(); } /** * Not supported. */ public Map processAll(Set> setEntries) { throw new UnsupportedOperationException(); } // ---- data members ---------------------------------------------------- /** * The underlying entry processor. */ protected final InvocableMap.EntryProcessor f_processor; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy