Class RedisAtomicInteger
java.lang.Object
java.lang.Number
org.springframework.data.redis.support.atomic.RedisAtomicInteger
- All Implemented Interfaces:
- Serializable,- BoundKeyOperations<String>
Atomic integer backed by Redis. Uses Redis atomic increment/decrement and watch/multi/exec operations for CAS
 operations.
- Author:
- Costin Leau, Thomas Darimont, Christoph Strobl, Mark Paluch, Graham MacMaster, Ning Wei
- See Also:
- 
Constructor SummaryConstructorsConstructorDescriptionRedisAtomicInteger(String redisCounter, RedisConnectionFactory factory) Constructs a newRedisAtomicIntegerinstance.RedisAtomicInteger(String redisCounter, RedisConnectionFactory factory, int initialValue) Constructs a newRedisAtomicIntegerinstance with ainitialValuethat overwrites the existing value.RedisAtomicInteger(String redisCounter, RedisOperations<String, Integer> template) Constructs a newRedisAtomicIntegerinstance.RedisAtomicInteger(String redisCounter, RedisOperations<String, Integer> template, int initialValue) Constructs a newRedisAtomicIntegerinstance instance with ainitialValuethat overwrites the existing value.
- 
Method SummaryModifier and TypeMethodDescriptionintaccumulateAndGet(int updateValue, IntBinaryOperator accumulatorFunction) Atomically update the current value using the givenaccumulator function.intaddAndGet(int delta) Atomically add the given value to current value.booleancompareAndSet(int expect, int update) Atomically set the value to the given updated value if the current value==the expected value.intAtomically decrement by one the current value.doubleSets the key time-to-live/expiration.Sets the key time-to-live/expiration.floatintget()Get the current value.intgetAndAccumulate(int updateValue, IntBinaryOperator accumulatorFunction) Atomically update the current value using the givenaccumulator function.intgetAndAdd(int delta) Atomically add the given value to current value.intAtomically decrement by one the current value.intAtomically increment by one the current value.intgetAndSet(int newValue) Set to the given value and return the old value.intgetAndUpdate(IntUnaryOperator updateFunction) Atomically update the current value using the givenupdate function.Returns the expiration of this key.getKey()Returns the key associated with this entity.getType()Returns the associated Redis type.intAtomically increment by one the current value.intintValue()longpersist()Removes the expiration (if any) of the key.voidRenames the key.voidset(int newValue) Set to the given value.toString()intupdateAndGet(IntUnaryOperator updateFunction) Atomically update the current value using the givenupdate function.Methods inherited from class java.lang.NumberbyteValue, shortValueMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.data.redis.core.BoundKeyOperationsexpire, expireAt
- 
Constructor Details- 
RedisAtomicIntegerConstructs a newRedisAtomicIntegerinstance. Uses the value existing in Redis or0if none is found.- Parameters:
- redisCounter- Redis key of this counter.
- factory- connection factory.
 
- 
RedisAtomicIntegerConstructs a newRedisAtomicIntegerinstance with ainitialValuethat overwrites the existing value.- Parameters:
- redisCounter- Redis key of this counter.
- factory- connection factory.
- initialValue- initial value to set.
 
- 
RedisAtomicIntegerConstructs a newRedisAtomicIntegerinstance. Uses the value existing in Redis or0if none is found.- Parameters:
- redisCounter- Redis key of this counter.
- template- the template.
- See Also:
 
- 
RedisAtomicIntegerpublic RedisAtomicInteger(String redisCounter, RedisOperations<String, Integer> template, int initialValue) Constructs a newRedisAtomicIntegerinstance instance with ainitialValuethat overwrites the existing value.Note: You need to configure the given templatewith appropriateRedisSerializerfor the key and value.As an alternative one could use the RedisAtomicInteger(String, RedisConnectionFactory, Integer)constructor which uses appropriate default serializers.- Parameters:
- redisCounter- Redis key of this counter.
- template- the template.
- initialValue- initial value to set if the Redis key is absent.
 
 
- 
- 
Method Details- 
getpublic int get()Get the current value.- Returns:
- the current value.
 
- 
setpublic void set(int newValue) Set to the given value.- Parameters:
- newValue- the new value.
 
- 
getAndSetpublic int getAndSet(int newValue) Set to the given value and return the old value.- Parameters:
- newValue- the new value.
- Returns:
- the previous value.
 
- 
compareAndSetpublic boolean compareAndSet(int expect, int update) Atomically set the value to the given updated value if the current value==the expected value.- Parameters:
- expect- the expected value.
- update- the new value.
- Returns:
- true if successful. false indicates that the actual value was not equal to the expected value.
 
- 
getAndIncrementpublic int getAndIncrement()Atomically increment by one the current value.- Returns:
- the previous value.
 
- 
getAndDecrementpublic int getAndDecrement()Atomically decrement by one the current value.- Returns:
- the previous value.
 
- 
getAndAddpublic int getAndAdd(int delta) Atomically add the given value to current value.- Parameters:
- delta- the value to add.
- Returns:
- the previous value.
 
- 
getAndUpdateAtomically update the current value using the givenupdate function.- Parameters:
- updateFunction- the function which calculates the value to set. Should be a pure function (no side effects), because it will be applied several times if update attempts fail due to concurrent calls. Must not be null.
- Returns:
- the previous value.
- Since:
- 2.2
 
- 
getAndAccumulateAtomically update the current value using the givenaccumulator function. The new value is calculated by applying the accumulator function to the current value and the givenupdateValue.- Parameters:
- updateValue- the value which will be passed into the accumulator function.
- accumulatorFunction- the function which calculates the value to set. Should be a pure function (no side effects), because it will be applied several times if update attempts fail due to concurrent calls. Must not be null.
- Returns:
- the previous value.
- Since:
- 2.2
 
- 
incrementAndGetpublic int incrementAndGet()Atomically increment by one the current value.- Returns:
- the updated value.
 
- 
decrementAndGetpublic int decrementAndGet()Atomically decrement by one the current value.- Returns:
- the updated value.
 
- 
addAndGetpublic int addAndGet(int delta) Atomically add the given value to current value.- Parameters:
- delta- the value to add.
- Returns:
- the updated value.
 
- 
updateAndGetAtomically update the current value using the givenupdate function.- Parameters:
- updateFunction- the function which calculates the value to set. Should be a pure function (no side effects), because it will be applied several times if update attempts fail due to concurrent calls. Must not be null.
- Returns:
- the updated value.
- Since:
- 2.2
 
- 
accumulateAndGetAtomically update the current value using the givenaccumulator function. The new value is calculated by applying the accumulator function to the current value and the givenupdateValue.- Parameters:
- updateValue- the value which will be passed into the accumulator function.
- accumulatorFunction- the function which calculates the value to set. Should be a pure function (no side effects), because it will be applied several times if update attempts fail due to concurrent calls. Must not be null.
- Returns:
- the updated value.
- Since:
- 2.2
 
- 
toString
- 
getKeyDescription copied from interface:BoundKeyOperationsReturns the key associated with this entity.- Specified by:
- getKeyin interface- BoundKeyOperations<String>
- Returns:
- key associated with the implementing entity
 
- 
getTypeDescription copied from interface:BoundKeyOperationsReturns the associated Redis type.- Specified by:
- getTypein interface- BoundKeyOperations<String>
- Returns:
- key type. null when used in pipeline / transaction.
 
- 
getExpireDescription copied from interface:BoundKeyOperationsReturns the expiration of this key.- Specified by:
- getExpirein interface- BoundKeyOperations<String>
- Returns:
- expiration value (in seconds). null when used in pipeline / transaction.
 
- 
expireDescription copied from interface:BoundKeyOperationsSets the key time-to-live/expiration.- Specified by:
- expirein interface- BoundKeyOperations<String>
- Parameters:
- timeout- expiration value
- unit- expiration unit
- Returns:
- true if expiration was set, false otherwise. null when used in pipeline / transaction.
 
- 
expireAtDescription copied from interface:BoundKeyOperationsSets the key time-to-live/expiration.- Specified by:
- expireAtin interface- BoundKeyOperations<String>
- Parameters:
- date- expiration date
- Returns:
- true if expiration was set, false otherwise. null when used in pipeline / transaction.
 
- 
persistDescription copied from interface:BoundKeyOperationsRemoves the expiration (if any) of the key.- Specified by:
- persistin interface- BoundKeyOperations<String>
- Returns:
- true if expiration was removed, false otherwise. null when used in pipeline / transaction.
 
- 
renameDescription copied from interface:BoundKeyOperationsRenames the key.
 Note: The new name for empty collections will be propagated on add of first element.- Specified by:
- renamein interface- BoundKeyOperations<String>
- Parameters:
- newKey- new key. Must not be null.
 
- 
intValuepublic int intValue()
- 
longValuepublic long longValue()
- 
floatValuepublic float floatValue()- Specified by:
- floatValuein class- Number
 
- 
doubleValuepublic double doubleValue()- Specified by:
- doubleValuein class- Number
 
 
-