/* * Written by Doug Lea with assistance from members of JCP JSR-166 * Expert Group and released to the public domain, as explained at * http://creativecommons.org/licenses/publicdomain * * Modified for IKVM.NET by Jeroen Frijters */ /* Parts Copyright (C) 2006 Jeroen Frijters This software is provided 'as-is', without any express or implied warranty. In no event will the authors be held liable for any damages arising from the use of this software. Permission is granted to anyone to use this software for any purpose, including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions: 1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. 3. This notice may not be removed or altered from any source distribution. Jeroen Frijters jeroen@frijters.net */ package java.util.concurrent.atomic; /** * A <tt>long</tt> value that may be updated atomically. See the * {@link java.util.concurrent.atomic} package specification for * description of the properties of atomic variables. An * <tt>AtomicLong</tt> is used in applications such as atomically * incremented sequence numbers, and cannot be used as a replacement * for a {@link java.lang.Long}. However, this class does extend * <tt>Number</tt> to allow uniform access by tools and utilities that * deal with numerically-based classes. * * @since 1.5 * @author Doug Lea */ public class AtomicLong extends Number implements java.io.Serializable { private static final long serialVersionUID = 1927816293512124184L; /** * Records whether the underlying JVM supports lockless * CompareAndSet for longs. While the unsafe.CompareAndSetLong * method works in either case, some constructions should be * handled at Java level to avoid locking user-visible locks. */ static final boolean VM_SUPPORTS_LONG_CAS = false; private long value; /** * Creates a new AtomicLong with the given initial value. * * @param initialValue the initial value */ public AtomicLong(long initialValue) { set(initialValue); } /** * Creates a new AtomicLong with initial value <tt>0</tt>. */ public AtomicLong() { } /** * Gets the current value. * * @return the current value */ public final synchronized long get() { return value; } /** * Sets to the given value. * * @param newValue the new value */ public final synchronized void set(long newValue) { value = newValue; } /** * Eventually sets to the given value. * * @param newValue the new value * @since 1.6 */ public final void lazySet(long newValue) { set(newValue); } /** * Atomically sets to the given value and returns the old value. * * @param newValue the new value * @return the previous value */ public final synchronized long getAndSet(long newValue) { long v = value; value = newValue; return v; } /** * Atomically sets the value to the given updated value * if the current value <tt>==</tt> the expected value. * * @param expect the expected value * @param update the new value * @return true if successful. False return indicates that * the actual value was not equal to the expected value. */ public final synchronized boolean compareAndSet(long expect, long update) { if (value == expect) { value = update; return true; } return false; } /** * Atomically sets the value to the given updated value * if the current value <tt>==</tt> the expected value. * May fail spuriously and does not provide ordering guarantees, * so is only rarely an appropriate alternative to <tt>compareAndSet</tt>. * * @param expect the expected value * @param update the new value * @return true if successful. */ public final boolean weakCompareAndSet(long expect, long update) { return compareAndSet(expect, update); } /** * Atomically increments by one the current value. * * @return the previous value */ public final synchronized long getAndIncrement() { return value++; } /** * Atomically decrements by one the current value. * * @return the previous value */ public final synchronized long getAndDecrement() { return value--; } /** * Atomically adds the given value to the current value. * * @param delta the value to add * @return the previous value */ public final synchronized long getAndAdd(long delta) { long v = value; value += delta; return v; } /** * Atomically increments by one the current value. * * @return the updated value */ public final synchronized long incrementAndGet() { return ++value; } /** * Atomically decrements by one the current value. * * @return the updated value */ public final synchronized long decrementAndGet() { return --value; } /** * Atomically adds the given value to the current value. * * @param delta the value to add * @return the updated value */ public final synchronized long addAndGet(long delta) { value += delta; return value; } /** * Returns the String representation of the current value. * @return the String representation of the current value. */ public String toString() { return Long.toString(get()); } public int intValue() { return (int)get(); } public long longValue() { return (long)get(); } public float floatValue() { return (float)get(); } public double doubleValue() { return (double)get(); } }