Package org.infinispan.counter.api
Interface StrongCounter
public interface StrongCounter
The strong consistent counter interface.
 
 It provides atomic updates for the counter. All the operations are perform asynchronously and they complete the
 CompletableFuture when completed.
- Since:
- 9.0
- Author:
- Pedro Ruivo
- 
Method SummaryModifier and TypeMethodDescriptionaddAndGet(long delta) Atomically adds the given value and return the new value.<T extends CounterListener>
 Handle<T>addListener(T listener) Registers aCounterListenerto this counter.default CompletableFuture<Boolean>compareAndSet(long expect, long update) Atomically sets the value to the given updated value if the current value==the expected value.compareAndSwap(long expect, long update) Atomically sets the value to the given updated value if the current value==the expected value.default CompletableFuture<Long>Atomically decrements the counter and returns the new valuegetName()getValue()It fetches the current value.default CompletableFuture<Long>Atomically increments the counter and returns the new value.remove()It removes this counter from the cluster.reset()Resets the counter to its initial value.sync()It returns a synchronous strong counter for this instance.
- 
Method Details- 
getNameString getName()- Returns:
- The counter name.
 
- 
getValueCompletableFuture<Long> getValue()It fetches the current value.It may go remotely to fetch the current value. - Returns:
- The current value.
 
- 
incrementAndGetAtomically increments the counter and returns the new value.- Returns:
- The new value.
 
- 
decrementAndGetAtomically decrements the counter and returns the new value- Returns:
- The new value.
 
- 
addAndGetAtomically adds the given value and return the new value.- Parameters:
- delta- The non-zero value to add. It can be negative.
- Returns:
- The new value.
 
- 
resetCompletableFuture<Void> reset()Resets the counter to its initial value.
- 
addListenerRegisters aCounterListenerto this counter.- Type Parameters:
- T- The concrete type of the listener. It must implement- CounterListener.
- Parameters:
- listener- The listener to register.
- Returns:
- A Handlethat allows to remove the listener viaHandle.remove().
 
- 
compareAndSetAtomically sets the value to the given updated value if the current value==the expected value. It is the same asreturn compareAndSwap(expect, update).thenApply(value -> value == expect);- Parameters:
- expect- the expected value
- update- the new value
- Returns:
- trueif successful,- falseotherwise.
 
- 
compareAndSwapAtomically sets the value to the given updated value if the current value==the expected value. The operation is successful if the return value is equals to the expected value.- Parameters:
- expect- the expected value.
- update- the new value.
- Returns:
- the previous counter's value.
 
- 
getConfigurationCounterConfiguration getConfiguration()- Returns:
- the CounterConfigurationused by this counter.
 
- 
removeCompletableFuture<Void> remove()It removes this counter from the cluster.Note that it doesn't remove the counter from the CounterManager. If you want to remove the counter from theCounterManageruseCounterManager.remove(String).- Returns:
- The CompletableFuturethat is completed when the counter is removed from the cluster.
 
- 
syncSyncStrongCounter sync()It returns a synchronous strong counter for this instance.- Returns:
- a SyncStrongCounter.
 
 
-