java.lang.Object
dev.mccue.guava.concurrent.Uninterruptibles
Utilities for treating interruptible operations as uninterruptible. In all cases, if a thread is
interrupted during such a call, the call continues to block until the result is available or the
timeout elapses, and only then re-interrupts the thread.
- Since:
- 10.0
- Author:
- Anthony Zana
-
Method Summary
Modifier and TypeMethodDescriptionstatic voidInvokesexecutor.awaitTermination(long, TimeUnit)uninterruptibly with no timeout.static booleanawaitTerminationUninterruptibly(ExecutorService executor, long timeout, TimeUnit unit) Invokesexecutor.awaitTermination(long, TimeUnit)uninterruptibly.static booleanawaitTerminationUninterruptibly(ExecutorService executor, Duration timeout) Invokesexecutor.awaitTermination(long, TimeUnit)uninterruptibly.static voidInvokeslatch.await()uninterruptibly.static booleanawaitUninterruptibly(CountDownLatch latch, long timeout, TimeUnit unit) Invokeslatch.await(timeout, unit)uninterruptibly.static booleanawaitUninterruptibly(CountDownLatch latch, Duration timeout) Invokeslatch.await(timeout, unit)uninterruptibly.static booleanawaitUninterruptibly(Condition condition, long timeout, TimeUnit unit) Invokescondition.await(timeout, unit)uninterruptibly.static booleanawaitUninterruptibly(Condition condition, Duration timeout) Invokescondition.await(timeout, unit)uninterruptibly.static <V extends @Nullable Object>
VgetUninterruptibly(Future<V> future) Invokesfuture.get()uninterruptibly.static <V extends @Nullable Object>
VgetUninterruptibly(Future<V> future, long timeout, TimeUnit unit) Invokesfuture.get(timeout, unit)uninterruptibly.static <V extends @Nullable Object>
VgetUninterruptibly(Future<V> future, Duration timeout) Invokesfuture.get(timeout, unit)uninterruptibly.static voidjoinUninterruptibly(Thread toJoin) InvokestoJoin.join()uninterruptibly.static voidjoinUninterruptibly(Thread toJoin, long timeout, TimeUnit unit) Invokesunit.timedJoin(toJoin, timeout)uninterruptibly.static voidjoinUninterruptibly(Thread toJoin, Duration timeout) Invokesunit.timedJoin(toJoin, timeout)uninterruptibly.static <E> voidputUninterruptibly(BlockingQueue<E> queue, E element) Invokesqueue.put(element)uninterruptibly.static voidsleepUninterruptibly(long sleepFor, TimeUnit unit) Invokesunit.sleep(sleepFor)uninterruptibly.static voidsleepUninterruptibly(Duration sleepFor) Invokesunit.sleep(sleepFor)uninterruptibly.static <E> EtakeUninterruptibly(BlockingQueue<E> queue) Invokesqueue.take()uninterruptibly.static booleantryAcquireUninterruptibly(Semaphore semaphore, int permits, long timeout, TimeUnit unit) Invokessemaphore.tryAcquire(permits, timeout, unit)uninterruptibly.static booleantryAcquireUninterruptibly(Semaphore semaphore, int permits, Duration timeout) Invokessemaphore.tryAcquire(permits, timeout, unit)uninterruptibly.static booleantryAcquireUninterruptibly(Semaphore semaphore, long timeout, TimeUnit unit) Invokessemaphore.tryAcquire(1, timeout, unit)uninterruptibly.static booleantryAcquireUninterruptibly(Semaphore semaphore, Duration timeout) Invokessemaphore.tryAcquire(1, timeout, unit)uninterruptibly.static booleantryLockUninterruptibly(Lock lock, long timeout, TimeUnit unit) Invokeslock.tryLock(timeout, unit)uninterruptibly.static booleantryLockUninterruptibly(Lock lock, Duration timeout) Invokeslock.tryLock(timeout, unit)uninterruptibly.
-
Method Details
-
awaitUninterruptibly
Invokeslatch.await()uninterruptibly. -
awaitUninterruptibly
Invokeslatch.await(timeout, unit)uninterruptibly.- Since:
- 28.0
-
awaitUninterruptibly
Invokeslatch.await(timeout, unit)uninterruptibly. -
awaitUninterruptibly
Invokescondition.await(timeout, unit)uninterruptibly.- Since:
- 28.0
-
awaitUninterruptibly
Invokescondition.await(timeout, unit)uninterruptibly.- Since:
- 23.6
-
joinUninterruptibly
InvokestoJoin.join()uninterruptibly. -
joinUninterruptibly
Invokesunit.timedJoin(toJoin, timeout)uninterruptibly.- Since:
- 28.0
-
joinUninterruptibly
Invokesunit.timedJoin(toJoin, timeout)uninterruptibly. -
getUninterruptibly
@CanIgnoreReturnValue public static <V extends @Nullable Object> V getUninterruptibly(Future<V> future) throws ExecutionException Invokesfuture.get()uninterruptibly.Similar methods:
- To retrieve a result from a
Futurethat is already done, useFutures.getDone. - To treat
InterruptedExceptionuniformly with other exceptions, useFutures.getChecked. - To get uninterruptibility and remove checked exceptions, use
Futures.getUnchecked(java.util.concurrent.Future<V>).
- Throws:
ExecutionException- if the computation threw an exceptionCancellationException- if the computation was cancelled
- To retrieve a result from a
-
getUninterruptibly
@CanIgnoreReturnValue public static <V extends @Nullable Object> V getUninterruptibly(Future<V> future, Duration timeout) throws ExecutionException, TimeoutException Invokesfuture.get(timeout, unit)uninterruptibly.Similar methods:
- To retrieve a result from a
Futurethat is already done, useFutures.getDone. - To treat
InterruptedExceptionuniformly with other exceptions, useFutures.getChecked. - To get uninterruptibility and remove checked exceptions, use
Futures.getUnchecked(java.util.concurrent.Future<V>).
- Throws:
ExecutionException- if the computation threw an exceptionCancellationException- if the computation was cancelledTimeoutException- if the wait timed out- Since:
- 28.0
- To retrieve a result from a
-
getUninterruptibly
@CanIgnoreReturnValue public static <V extends @Nullable Object> V getUninterruptibly(Future<V> future, long timeout, TimeUnit unit) throws ExecutionException, TimeoutException Invokesfuture.get(timeout, unit)uninterruptibly.Similar methods:
- To retrieve a result from a
Futurethat is already done, useFutures.getDone. - To treat
InterruptedExceptionuniformly with other exceptions, useFutures.getChecked. - To get uninterruptibility and remove checked exceptions, use
Futures.getUnchecked(java.util.concurrent.Future<V>).
- Throws:
ExecutionException- if the computation threw an exceptionCancellationException- if the computation was cancelledTimeoutException- if the wait timed out
- To retrieve a result from a
-
takeUninterruptibly
Invokesqueue.take()uninterruptibly. -
putUninterruptibly
Invokesqueue.put(element)uninterruptibly.- Throws:
ClassCastException- if the class of the specified element prevents it from being added to the given queueIllegalArgumentException- if some property of the specified element prevents it from being added to the given queue
-
sleepUninterruptibly
Invokesunit.sleep(sleepFor)uninterruptibly.- Since:
- 28.0
-
sleepUninterruptibly
Invokesunit.sleep(sleepFor)uninterruptibly. -
tryAcquireUninterruptibly
Invokessemaphore.tryAcquire(1, timeout, unit)uninterruptibly.- Since:
- 28.0
-
tryAcquireUninterruptibly
Invokessemaphore.tryAcquire(1, timeout, unit)uninterruptibly.- Since:
- 18.0
-
tryAcquireUninterruptibly
Invokessemaphore.tryAcquire(permits, timeout, unit)uninterruptibly.- Since:
- 28.0
-
tryAcquireUninterruptibly
public static boolean tryAcquireUninterruptibly(Semaphore semaphore, int permits, long timeout, TimeUnit unit) Invokessemaphore.tryAcquire(permits, timeout, unit)uninterruptibly.- Since:
- 18.0
-
tryLockUninterruptibly
Invokeslock.tryLock(timeout, unit)uninterruptibly.- Since:
- 30.0
-
tryLockUninterruptibly
Invokeslock.tryLock(timeout, unit)uninterruptibly.- Since:
- 30.0
-
awaitTerminationUninterruptibly
Invokesexecutor.awaitTermination(long, TimeUnit)uninterruptibly with no timeout.- Since:
- 30.0
-
awaitTerminationUninterruptibly
Invokesexecutor.awaitTermination(long, TimeUnit)uninterruptibly.- Since:
- 30.0
-
awaitTerminationUninterruptibly
public static boolean awaitTerminationUninterruptibly(ExecutorService executor, long timeout, TimeUnit unit) Invokesexecutor.awaitTermination(long, TimeUnit)uninterruptibly.- Since:
- 30.0
-