More safety in Acquired + doc

Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
TheMode 2021-09-12 06:29:33 +02:00
parent 7b059d2be5
commit c31aa8a7ec

View File

@ -6,28 +6,39 @@ import org.jetbrains.annotations.NotNull;
import java.util.concurrent.locks.ReentrantLock; import java.util.concurrent.locks.ReentrantLock;
/**
* Represents an object that has been safely acquired and can be freed again.
* <p>
* This class should not be shared, and it is recommended to call {@link #unlock()}
* once the acquisition goal has been fulfilled to limit blocking time.
*
* @param <T> the type of the acquired object
*/
public final class Acquired<T> { public final class Acquired<T> {
private final T value; private final T value;
private final Thread owner;
private final ReentrantLock lock; private final ReentrantLock lock;
private boolean unlocked; private boolean unlocked;
Acquired(T value, TickThread tickThread) { Acquired(T value, TickThread tickThread) {
this.value = value; this.value = value;
this.lock = AcquirableImpl.enter(Thread.currentThread(), tickThread); this.owner = Thread.currentThread();
this.lock = AcquirableImpl.enter(owner, tickThread);
} }
public @NotNull T get() { public @NotNull T get() {
checkLock(); safeCheck();
return value; return value;
} }
public void unlock() { public void unlock() {
checkLock(); safeCheck();
this.unlocked = true; this.unlocked = true;
AcquirableImpl.leave(lock); AcquirableImpl.leave(lock);
} }
private void checkLock() { private void safeCheck() {
Check.stateCondition(Thread.currentThread() != owner, "Acquired object is owned by the thread {0}", owner);
Check.stateCondition(unlocked, "The acquired element has already been unlocked!"); Check.stateCondition(unlocked, "The acquired element has already been unlocked!");
} }
} }