net.derquinse.common.util.concurrent.AtomicLongWaterMark Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of derquinse-common-base Show documentation
Show all versions of derquinse-common-base Show documentation
Module containing support classes depending on Java SE 6, Guava 11 and Joda-Time 2.0
/*
* Copyright (C) the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.derquinse.common.util.concurrent;
import static com.google.common.base.Preconditions.checkNotNull;
import static com.google.common.util.concurrent.Atomics.newReference;
import java.util.concurrent.atomic.AtomicReference;
import net.derquinse.common.base.LongWaterMark;
import com.google.common.base.Objects;
/**
* An atomic LongWaterMark. Provide access to the same mutation methods in a thread-safe way.
* @author Andres Rodriguez
*/
public final class AtomicLongWaterMark {
/** Current value. */
private final AtomicReference ref;
/**
* Creates a new high watermark with the provided initial value.
* @param initialValue Inital value.
* @return The created object.
*/
public static final AtomicLongWaterMark of(LongWaterMark initialValue) {
return new AtomicLongWaterMark(initialValue);
}
/**
* Creates a new object with the provided initial value.
* @param initialValue Inital value.
* @return The created object.
*/
public static final AtomicLongWaterMark of(long initialValue) {
return of(LongWaterMark.of(initialValue));
}
/**
* Creates a new object with initial value 0.
* @return The created object.
*/
public static final AtomicLongWaterMark of() {
return of(0);
}
private AtomicLongWaterMark(LongWaterMark initialValue) {
this.ref = newReference(checkNotNull(initialValue, "Null initial values not allowed"));
}
/**
* Returns the current value.
*/
public LongWaterMark get() {
return ref.get();
}
/**
* Sets the current value.
* @param value Value to set.
* @return The value set.
*/
public LongWaterMark set(long value) {
LongWaterMark current;
LongWaterMark newValue;
do {
current = ref.get();
newValue = current.set(value);
if (current == newValue) {
return current;
}
} while (!ref.compareAndSet(current, newValue));
return newValue;
}
/**
* Sets the value if the current reference is the same as the provided one.
* @param expected Expected current reference.
* @param value Value to set.
* @return If the update was successful.
*/
public boolean compareAndSet(LongWaterMark expected, long value) {
return ref.compareAndSet(expected, expected.set(value));
}
/**
* Sets the value if the current one is the same as the provided one.
* @param expected Expected current value.
* @param value Value to set.
* @return If the update was successful.
*/
public boolean compareAndSet(int expected, long value) {
final LongWaterMark current = ref.get();
if (current.get() == expected) {
return compareAndSet(current, value);
}
return false;
}
/**
* Adds a certain amount to the current value.
* @param value Value to add.
* @return The value set.
*/
public LongWaterMark add(long value) {
LongWaterMark current;
LongWaterMark newValue;
do {
current = ref.get();
newValue = current.add(value);
} while (!ref.compareAndSet(current, newValue));
return newValue;
}
/**
* Adds a certain amount to the current value if the current reference is the same as the provided
* one.
* @param expected Expected current reference.
* @param value Value to set.
* @return If the update was successful.
*/
public boolean compareAndAdd(LongWaterMark expected, long value) {
return ref.compareAndSet(expected, expected.add(value));
}
/**
* Adds a certain amount to the current value if it is the same as the provided one.
* @param expected Expected current value.
* @param value Value to set.
* @return If the update was successful.
*/
public boolean compareAndAdd(int expected, long value) {
final LongWaterMark current = ref.get();
if (current.get() == expected) {
return compareAndAdd(current, value);
}
return false;
}
/**
* Adds one to the current value.
* @return The value set.
*/
public LongWaterMark inc() {
return add(1);
}
/**
* Subtract one to the current value.
* @return The value set.
*/
public LongWaterMark dec() {
return add(-1);
}
@Override
public String toString() {
return Objects.toStringHelper(this).addValue(ref.get()).toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy