Package edu.rit.pj.reduction
Class SharedLong
java.lang.Object
java.lang.Number
edu.rit.pj.reduction.SharedLong
- All Implemented Interfaces:
- Serializable
Class SharedLong provides a reduction variable for a value of type
 
long.
 Class SharedLong is multiple thread safe. The methods use lock-free atomic compare-and-set.
Note: Class SharedLong is implemented using class java.util.concurrent.atomic.AtomicLong.
- Version:
- 07-Jun-2007
- Author:
- Alan Kaminsky
- See Also:
- 
Constructor SummaryConstructorsConstructorDescriptionConstruct a new long reduction variable with the initial value 0.SharedLong(long initialValue) Construct a new long reduction variable with the given initial value.
- 
Method SummaryModifier and TypeMethodDescriptionlongaddAndGet(long value) Add the given value to this reduction variable and return the new value.booleancompareAndSet(long expect, long update) Atomically set this reduction variable to the given updated value if the current value equals the expected value.longSubtract one from this reduction variable and return the new value.doubleReturns this reduction variable's current value converted to typedouble.floatReturns this reduction variable's current value converted to typefloat.longget()Returns this reduction variable's current value.longgetAndAdd(long value) Add the given value to this reduction variable and return the previous value.longSubtract one from this reduction variable and return the previous value.longAdd one to this reduction variable and return the previous value.longgetAndSet(long value) Set this reduction variable to the given value and return the previous value.longAdd one to this reduction variable and return the new value.intintValue()Returns this reduction variable's current value converted to typeint.longReturns this reduction variable's current value converted to typelong.longCombine this reduction variable with the given value using the given operation.voidset(long value) Set this reduction variable to the given value.toString()Returns a string version of this reduction variable.booleanweakCompareAndSet(long expect, long update) Atomically set this reduction variable to the given updated value if the current value equals the expected value.Methods inherited from class java.lang.NumberbyteValue, shortValue
- 
Constructor Details- 
SharedLongpublic SharedLong()Construct a new long reduction variable with the initial value 0.
- 
SharedLongpublic SharedLong(long initialValue) Construct a new long reduction variable with the given initial value.- Parameters:
- initialValue- Initial value.
 
 
- 
- 
Method Details- 
getpublic long get()Returns this reduction variable's current value.- Returns:
- Current value.
 
- 
setpublic void set(long value) Set this reduction variable to the given value.- Parameters:
- value- New value.
 
- 
getAndSetpublic long getAndSet(long value) Set this reduction variable to the given value and return the previous value.- Parameters:
- value- New value.
- Returns:
- Previous value.
 
- 
compareAndSetpublic boolean compareAndSet(long expect, long update) Atomically set this reduction variable to the given updated value if the current value equals the expected value.- Parameters:
- expect- Expected value.
- update- Updated value.
- Returns:
- True if the update happened, false otherwise.
 
- 
weakCompareAndSetpublic boolean weakCompareAndSet(long expect, long update) Atomically set this reduction variable to the given updated value if the current value equals the expected value. May fail spuriously.- Parameters:
- expect- Expected value.
- update- Updated value.
- Returns:
- True if the update happened, false otherwise.
 
- 
getAndIncrementpublic long getAndIncrement()Add one to this reduction variable and return the previous value.- Returns:
- Previous value.
 
- 
getAndDecrementpublic long getAndDecrement()Subtract one from this reduction variable and return the previous value.- Returns:
- Previous value.
 
- 
getAndAddpublic long getAndAdd(long value) Add the given value to this reduction variable and return the previous value.- Parameters:
- value- Value to add.
- Returns:
- Previous value.
 
- 
incrementAndGetpublic long incrementAndGet()Add one to this reduction variable and return the new value.- Returns:
- New value.
 
- 
decrementAndGetpublic long decrementAndGet()Subtract one from this reduction variable and return the new value.- Returns:
- New value.
 
- 
addAndGetpublic long addAndGet(long value) Add the given value to this reduction variable and return the new value.- Parameters:
- value- Value to add.
- Returns:
- New value.
 
- 
reduceCombine this reduction variable with the given value using the given operation. The result is stored back into this reduction variable and is returned.- Parameters:
- value- Value.
- op- Binary operation.
- Returns:
- (This variable) op (value).
 
- 
toStringReturns a string version of this reduction variable.
- 
intValuepublic int intValue()Returns this reduction variable's current value converted to typeint.
- 
longValuepublic long longValue()Returns this reduction variable's current value converted to typelong.
- 
floatValuepublic float floatValue()Returns this reduction variable's current value converted to typefloat.- Specified by:
- floatValuein class- Number
- Returns:
- Current value.
 
- 
doubleValuepublic double doubleValue()Returns this reduction variable's current value converted to typedouble.- Specified by:
- doubleValuein class- Number
- Returns:
- Current value.
 
 
-