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

org.infinispan.api.async.AsyncStrongCounter Maven / Gradle / Ivy

The newest version!
package org.infinispan.api.async;

import java.util.concurrent.CompletionStage;
import java.util.function.Consumer;

import org.infinispan.api.common.events.counter.CounterEvent;
import org.infinispan.api.configuration.CounterConfiguration;

/**
 * The strong consistent counter interface.
 * 

* It provides atomic updates for the counter. All the operations are perform asynchronously and they complete the * {@link CompletionStage} when completed. * * @since 14.0 */ public interface AsyncStrongCounter { /** * @return The counter name. */ String name(); /** * Retrieves the counter's configuration. * * @return this counter's configuration. */ CompletionStage configuration(); /** * Return the container of this counter * * @return */ AsyncContainer container(); /** * It fetches the current value. *

* It may go remotely to fetch the current value. * * @return The current value. */ CompletionStage value(); /** * Atomically increments the counter and returns the new value. * * @return The new value. */ default CompletionStage incrementAndGet() { return addAndGet(1L); } /** * Atomically decrements the counter and returns the new value * * @return The new value. */ default CompletionStage decrementAndGet() { return addAndGet(-1L); } /** * Atomically adds the given value and return the new value. * * @param delta The non-zero value to add. It can be negative. * @return The new value. */ CompletionStage addAndGet(long delta); /** * Resets the counter to its initial value. */ CompletionStage reset(); /** * Registers a {@link Consumer} to this counter. * * @param listener The listener to register. * @return A {@link AutoCloseable} that allows to remove the listener via {@link AutoCloseable#close()}. */ CompletionStage listen(Consumer listener); /** * Atomically sets the value to the given updated value if the current value {@code ==} the expected value. *

* It is the same as {@code return compareAndSwap(expect, update).thenApply(value -> value == expect);} * * @param expect the expected value * @param update the new value * @return {@code true} if successful, {@code false} otherwise. */ default CompletionStage compareAndSet(long expect, long update) { return compareAndSwap(expect, update).thenApply(value -> value == expect); } /** * Atomically sets the value to the given updated value if the current value {@code ==} the expected value. *

* The operation is successful if the return value is equals to the expected value. * * @param expect the expected value. * @param update the new value. * @return the previous counter's value. */ CompletionStage compareAndSwap(long expect, long update); /** * Atomically sets the value to the given updated value * * @param value the new value. * @return the old counter value. */ CompletionStage getAndSet(long value); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy