Interface AtomicInteger
- All Known Implementing Classes:
- LocalAtomicInteger,- RemoteAtomicInteger
int value that may be updated atomically.
 
 An AtomicInteger is used in applications
 such as atomically incremented counters, and cannot be used
 as a replacement for an Integer.
- Since:
- 21.12
- Author:
- Aleks Seovic 2020.12.07
- 
Nested Class SummaryNested ClassesModifier and TypeInterfaceDescriptionstatic classPOF serializer implementation.
- 
Method SummaryModifier and TypeMethodDescriptionintaccumulateAndGet(int nUpdate, Remote.IntBinaryOperator accumulatorFunction) Atomically updates the current value with the results of applying the given function to the current and given values, returning the updated value.intaccumulateAndGet(int nUpdate, IntBinaryOperator accumulatorFunction) Atomically updates the current value with the results of applying the given function to the current and given values, returning the updated value.intaddAndGet(int nDelta) Atomically adds the given value to the current value.async()Return non-blocking API for this atomic value.byteReturns the current value of thisAtomicIntegeras abyteafter a narrowing primitive conversion.intcompareAndExchange(int nExpectedValue, int nNewValue) Atomically sets the value tonewValueif the current value, referred to as the witness value,== expectedValue.booleancompareAndSet(int nExpectedValue, int nNewValue) Atomically sets the value tonewValueif the current value== expectedValue.intAtomically decrements the current value.doubleReturns the current value of thisAtomicIntegeras adoubleafter a widening primitive conversion.floatReturns the current value of thisAtomicIntegeras afloatafter a widening primitive conversion.intget()Returns the current value.intgetAndAccumulate(int nUpdate, Remote.IntBinaryOperator accumulatorFunction) Atomically updates the current value with the results of applying the given function to the current and given values, returning the previous value.intgetAndAccumulate(int nUpdate, IntBinaryOperator accumulatorFunction) Atomically updates the current value with the results of applying the given function to the current and given values, returning the previous value.intgetAndAdd(int nDelta) Atomically adds the given value to the current value.intAtomically decrements the current value.intAtomically increments the current value.intgetAndSet(int nNewValue) Atomically sets the value tonewValueand returns the old value.intgetAndUpdate(Remote.IntUnaryOperator updateFunction) Atomically updates the current value with the results of applying the given function, returning the previous value.intgetAndUpdate(IntUnaryOperator updateFunction) Atomically updates the current value with the results of applying the given function, returning the previous value.intAtomically increments the current value.intintValue()Returns the current value of thisAtomicIntegeras anint.longReturns the current value of thisAtomicIntegeras alongafter a widening primitive conversion.voidset(int nNewValue) Sets the value tonewValue.shortReturns the current value of thisAtomicIntegeras ashortafter a narrowing primitive conversion.intupdateAndGet(Remote.IntUnaryOperator updateFunction) Atomically updates the current value with the results of applying the given function, returning the updated value.intupdateAndGet(IntUnaryOperator updateFunction) Atomically updates the current value with the results of applying the given function, returning the updated value.
- 
Method Details- 
asyncAsyncAtomicInteger async()Return non-blocking API for this atomic value.- Returns:
- non-blocking API for this atomic value
 
- 
getint get()Returns the current value.- Returns:
- the current value
 
- 
setvoid set(int nNewValue) Sets the value tonewValue.- Parameters:
- nNewValue- the new value
 
- 
getAndSetint getAndSet(int nNewValue) Atomically sets the value tonewValueand returns the old value.- Parameters:
- nNewValue- the new value
- Returns:
- the previous value
 
- 
compareAndSetboolean compareAndSet(int nExpectedValue, int nNewValue) Atomically sets the value tonewValueif the current value== expectedValue.- Parameters:
- nExpectedValue- the expected value
- nNewValue- the new value
- Returns:
- trueif successful. False return indicates that the actual value was not equal to the expected value.
 
- 
getAndIncrementint getAndIncrement()Atomically increments the current value.Equivalent to getAndAdd(1).- Returns:
- the previous value
 
- 
getAndDecrementint getAndDecrement()Atomically decrements the current value.Equivalent to getAndAdd(-1).- Returns:
- the previous value
 
- 
getAndAddint getAndAdd(int nDelta) Atomically adds the given value to the current value.- Parameters:
- nDelta- the value to add
- Returns:
- the previous value
 
- 
incrementAndGetint incrementAndGet()Atomically increments the current value.Equivalent to addAndGet(1).- Returns:
- the updated value
 
- 
decrementAndGetint decrementAndGet()Atomically decrements the current value.Equivalent to addAndGet(-1).- Returns:
- the updated value
 
- 
addAndGetint addAndGet(int nDelta) Atomically adds the given value to the current value.- Parameters:
- nDelta- the value to add
- Returns:
- the updated value
 
- 
getAndUpdateAtomically updates the current value with the results of applying the given function, returning the previous value. The function should be side-effect-free, since it may be re-applied when attempted updates fail due to contention among threads.- Parameters:
- updateFunction- a side-effect-free function
- Returns:
- the previous value
 
- 
getAndUpdateAtomically updates the current value with the results of applying the given function, returning the previous value. The function should be side-effect-free, since it may be re-applied when attempted updates fail due to contention among threads.- Parameters:
- updateFunction- a side-effect-free function
- Returns:
- the previous value
 
- 
updateAndGetAtomically updates the current value with the results of applying the given function, returning the updated value. The function should be side-effect-free, since it may be re-applied when attempted updates fail due to contention among threads.- Parameters:
- updateFunction- a side-effect-free function
- Returns:
- the updated value
 
- 
updateAndGetAtomically updates the current value with the results of applying the given function, returning the updated value. The function should be side-effect-free, since it may be re-applied when attempted updates fail due to contention among threads.- Parameters:
- updateFunction- a side-effect-free function
- Returns:
- the updated value
 
- 
getAndAccumulateAtomically updates the current value with the results of applying the given function to the current and given values, returning the previous value.The function should beside-effect-free, since it may be re-applied when attempted updates fail due to contention among threads. The function is applied with the current value as its first argument, and the given update as the second argument. - Parameters:
- nUpdate- the update value
- accumulatorFunction- a side-effect-free function of two arguments
- Returns:
- the previous value
 
- 
getAndAccumulateAtomically updates the current value with the results of applying the given function to the current and given values, returning the previous value.The function should beside-effect-free, since it may be re-applied when attempted updates fail due to contention among threads. The function is applied with the current value as its first argument, and the given update as the second argument. - Parameters:
- nUpdate- the update value
- accumulatorFunction- a side-effect-free function of two arguments
- Returns:
- the previous value
 
- 
accumulateAndGetAtomically updates the current value with the results of applying the given function to the current and given values, returning the updated value.The function should be side-effect-free, since it may be re-applied when attempted updates fail due to contention among threads. The function is applied with the current value as its first argument, and the given update as the second argument. - Parameters:
- nUpdate- the update value
- accumulatorFunction- a side-effect-free function of two arguments
- Returns:
- the updated value
 
- 
accumulateAndGetAtomically updates the current value with the results of applying the given function to the current and given values, returning the updated value.The function should be side-effect-free, since it may be re-applied when attempted updates fail due to contention among threads. The function is applied with the current value as its first argument, and the given update as the second argument. - Parameters:
- nUpdate- the update value
- accumulatorFunction- a side-effect-free function of two arguments
- Returns:
- the updated value
 
- 
compareAndExchangeint compareAndExchange(int nExpectedValue, int nNewValue) Atomically sets the value tonewValueif the current value, referred to as the witness value,== expectedValue.- Parameters:
- nExpectedValue- the expected value
- nNewValue- the new value
- Returns:
- the witness value, which will be the same as the expected value if successful
 
- 
intValueint intValue()Returns the current value of thisAtomicIntegeras anint.- Returns:
- the numeric value represented by this object
 
- 
longValuelong longValue()Returns the current value of thisAtomicIntegeras alongafter a widening primitive conversion.- Returns:
- the numeric value represented by this object after conversion
         to type long
 
- 
floatValuefloat floatValue()Returns the current value of thisAtomicIntegeras afloatafter a widening primitive conversion.- Returns:
- the numeric value represented by this object after conversion
         to type float
 
- 
doubleValuedouble doubleValue()Returns the current value of thisAtomicIntegeras adoubleafter a widening primitive conversion.- Returns:
- the numeric value represented by this object after conversion
         to type double
 
- 
byteValuebyte byteValue()Returns the current value of thisAtomicIntegeras abyteafter a narrowing primitive conversion.- Returns:
- the numeric value represented by this object after conversion
         to type byte
 
- 
shortValueshort shortValue()Returns the current value of thisAtomicIntegeras ashortafter a narrowing primitive conversion.- Returns:
- the numeric value represented by this object after conversion
         to type short
 
 
-