Class Uninterruptibles
java.lang.Object
org.docx4j.com.google.common.util.concurrent.Uninterruptibles
@GwtCompatible(emulated=true) public final class Uninterruptibles extends java.lang.Object
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 Type Method Description static voidawaitUninterruptibly(java.util.concurrent.CountDownLatch latch)Invokeslatch.await()uninterruptibly.static booleanawaitUninterruptibly(java.util.concurrent.CountDownLatch latch, long timeout, java.util.concurrent.TimeUnit unit)Invokeslatch.await(timeout, unit)uninterruptibly.static booleanawaitUninterruptibly(java.util.concurrent.locks.Condition condition, long timeout, java.util.concurrent.TimeUnit unit)Invokescondition.await(timeout, unit)uninterruptibly.static <V> VgetUninterruptibly(java.util.concurrent.Future<V> future)Invokesfuture.get()uninterruptibly.static <V> VgetUninterruptibly(java.util.concurrent.Future<V> future, long timeout, java.util.concurrent.TimeUnit unit)Invokesfuture.get(timeout, unit)uninterruptibly.static voidjoinUninterruptibly(java.lang.Thread toJoin)InvokestoJoin.join()uninterruptibly.static voidjoinUninterruptibly(java.lang.Thread toJoin, long timeout, java.util.concurrent.TimeUnit unit)Invokesunit.timedJoin(toJoin, timeout)uninterruptibly.static <E> voidputUninterruptibly(java.util.concurrent.BlockingQueue<E> queue, E element)Invokesqueue.put(element)uninterruptibly.static voidsleepUninterruptibly(long sleepFor, java.util.concurrent.TimeUnit unit)Invokesunit.sleep(sleepFor)uninterruptibly.static <E> EtakeUninterruptibly(java.util.concurrent.BlockingQueue<E> queue)Invokesqueue.take()uninterruptibly.static booleantryAcquireUninterruptibly(java.util.concurrent.Semaphore semaphore, int permits, long timeout, java.util.concurrent.TimeUnit unit)Invokessemaphore.tryAcquire(permits, timeout, unit)uninterruptibly.static booleantryAcquireUninterruptibly(java.util.concurrent.Semaphore semaphore, long timeout, java.util.concurrent.TimeUnit unit)Invokessemaphore.tryAcquire(1, timeout, unit)uninterruptibly.
-
Method Details
-
awaitUninterruptibly
@GwtIncompatible public static void awaitUninterruptibly(java.util.concurrent.CountDownLatch latch)Invokeslatch.await()uninterruptibly. -
awaitUninterruptibly
@CanIgnoreReturnValue @GwtIncompatible public static boolean awaitUninterruptibly(java.util.concurrent.CountDownLatch latch, long timeout, java.util.concurrent.TimeUnit unit)Invokeslatch.await(timeout, unit)uninterruptibly. -
awaitUninterruptibly
@GwtIncompatible public static boolean awaitUninterruptibly(java.util.concurrent.locks.Condition condition, long timeout, java.util.concurrent.TimeUnit unit)Invokescondition.await(timeout, unit)uninterruptibly.- Since:
- 23.6
-
joinUninterruptibly
InvokestoJoin.join()uninterruptibly. -
joinUninterruptibly
@GwtIncompatible public static void joinUninterruptibly(java.lang.Thread toJoin, long timeout, java.util.concurrent.TimeUnit unit)Invokesunit.timedJoin(toJoin, timeout)uninterruptibly. -
getUninterruptibly
@CanIgnoreReturnValue public static <V> V getUninterruptibly(java.util.concurrent.Future<V> future) throws java.util.concurrent.ExecutionExceptionInvokesfuture.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.
- Throws:
java.util.concurrent.ExecutionException- if the computation threw an exceptionjava.util.concurrent.CancellationException- if the computation was cancelled
- To retrieve a result from a
-
getUninterruptibly
@CanIgnoreReturnValue @GwtIncompatible public static <V> V getUninterruptibly(java.util.concurrent.Future<V> future, long timeout, java.util.concurrent.TimeUnit unit) throws java.util.concurrent.ExecutionException, java.util.concurrent.TimeoutExceptionInvokesfuture.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.
- Throws:
java.util.concurrent.ExecutionException- if the computation threw an exceptionjava.util.concurrent.CancellationException- if the computation was cancelledjava.util.concurrent.TimeoutException- if the wait timed out
- To retrieve a result from a
-
takeUninterruptibly
@GwtIncompatible public static <E> E takeUninterruptibly(java.util.concurrent.BlockingQueue<E> queue)Invokesqueue.take()uninterruptibly. -
putUninterruptibly
@GwtIncompatible public static <E> void putUninterruptibly(java.util.concurrent.BlockingQueue<E> queue, E element)Invokesqueue.put(element)uninterruptibly.- Throws:
java.lang.ClassCastException- if the class of the specified element prevents it from being added to the given queuejava.lang.IllegalArgumentException- if some property of the specified element prevents it from being added to the given queue
-
sleepUninterruptibly
@GwtIncompatible public static void sleepUninterruptibly(long sleepFor, java.util.concurrent.TimeUnit unit)Invokesunit.sleep(sleepFor)uninterruptibly. -
tryAcquireUninterruptibly
@GwtIncompatible public static boolean tryAcquireUninterruptibly(java.util.concurrent.Semaphore semaphore, long timeout, java.util.concurrent.TimeUnit unit)Invokessemaphore.tryAcquire(1, timeout, unit)uninterruptibly.- Since:
- 18.0
-
tryAcquireUninterruptibly
@GwtIncompatible public static boolean tryAcquireUninterruptibly(java.util.concurrent.Semaphore semaphore, int permits, long timeout, java.util.concurrent.TimeUnit unit)Invokessemaphore.tryAcquire(permits, timeout, unit)uninterruptibly.- Since:
- 18.0
-