public class AbstractQueuedLongSynchronizer.ConditionObject extends Object implements Condition, Serializable
AbstractQueuedLongSynchronizer serving as the basis of a Lock implementation.
 Method documentation for this class describes mechanics, not behavioral specifications from the point of view of Lock and Condition users. Exported versions of this class will in general need to be accompanied by documentation describing condition semantics that rely on those of the associated AbstractQueuedLongSynchronizer.
This class is Serializable, but all fields are transient, so deserialized conditions have no waiters.
| Constructor and Description | 
|---|
| AbstractQueuedLongSynchronizer.ConditionObject()Creates a new ConditionObject instance. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | await()Implements interruptible condition wait. | 
| boolean | await(long time,
     TimeUnit unit)Implements timed condition wait. | 
| long | awaitNanos(long nanosTimeout)Implements timed condition wait. | 
| void | awaitUninterruptibly()Implements uninterruptible condition wait. | 
| boolean | awaitUntil(Date deadline)Implements absolute timed condition wait. | 
| protected Collection<Thread> | getWaitingThreads()Returns a collection containing those threads that may be
 waiting on this Condition. | 
| protected int | getWaitQueueLength()Returns an estimate of the number of threads waiting on
 this condition. | 
| protected boolean | hasWaiters()Queries whether any threads are waiting on this condition. | 
| void | signal()Moves the longest-waiting thread, if one exists, from the
 wait queue for this condition to the wait queue for the
 owning lock. | 
| void | signalAll()Moves all threads from the wait queue for this condition to
 the wait queue for the owning lock. | 
public AbstractQueuedLongSynchronizer.ConditionObject()
public final void signal()
signal in interface ConditionIllegalMonitorStateException - if AbstractQueuedLongSynchronizer.isHeldExclusively()
         returns falsepublic final void signalAll()
signalAll in interface ConditionIllegalMonitorStateException - if AbstractQueuedLongSynchronizer.isHeldExclusively()
         returns falsepublic final void awaitUninterruptibly()
AbstractQueuedLongSynchronizer.getState().
 AbstractQueuedLongSynchronizer.release(long) with
      saved state as argument, throwing
      IllegalMonitorStateException if it fails.
 AbstractQueuedLongSynchronizer.acquire(long) with saved state as argument.
 awaitUninterruptibly in interface Conditionpublic final void await()
                 throws InterruptedException
AbstractQueuedLongSynchronizer.getState().
 AbstractQueuedLongSynchronizer.release(long) with
      saved state as argument, throwing
      IllegalMonitorStateException if it fails.
 AbstractQueuedLongSynchronizer.acquire(long) with saved state as argument.
 await in interface ConditionInterruptedException - if the current thread is interrupted
         (and interruption of thread suspension is supported)public final long awaitNanos(long nanosTimeout)
                      throws InterruptedException
AbstractQueuedLongSynchronizer.getState().
 AbstractQueuedLongSynchronizer.release(long) with
      saved state as argument, throwing
      IllegalMonitorStateException if it fails.
 AbstractQueuedLongSynchronizer.acquire(long) with saved state as argument.
 awaitNanos in interface ConditionnanosTimeout - the maximum time to wait, in nanosecondsnanosTimeout value minus
         the time spent waiting upon return from this method.
         A positive value may be used as the argument to a
         subsequent call to this method to finish waiting out
         the desired time.  A value less than or equal to zero
         indicates that no time remains.InterruptedException - if the current thread is interrupted
         (and interruption of thread suspension is supported)public final boolean awaitUntil(Date deadline) throws InterruptedException
AbstractQueuedLongSynchronizer.getState().
 AbstractQueuedLongSynchronizer.release(long) with
      saved state as argument, throwing
      IllegalMonitorStateException if it fails.
 AbstractQueuedLongSynchronizer.acquire(long) with saved state as argument.
 awaitUntil in interface Conditiondeadline - the absolute time to wait untilfalse if the deadline has elapsed upon return, else
         trueInterruptedException - if the current thread is interrupted
         (and interruption of thread suspension is supported)public final boolean await(long time,
            TimeUnit unit)
                    throws InterruptedException
AbstractQueuedLongSynchronizer.getState().
 AbstractQueuedLongSynchronizer.release(long) with
      saved state as argument, throwing
      IllegalMonitorStateException if it fails.
 AbstractQueuedLongSynchronizer.acquire(long) with saved state as argument.
 await in interface Conditiontime - the maximum time to waitunit - the time unit of the time argumentfalse if the waiting time detectably elapsed
         before return from the method, else trueInterruptedException - if the current thread is interrupted
         (and interruption of thread suspension is supported)protected final boolean hasWaiters()
AbstractQueuedLongSynchronizer.hasWaiters(java.util.concurrent.locks.AbstractQueuedLongSynchronizer.ConditionObject).true if there are any waiting threadsIllegalMonitorStateException - if AbstractQueuedLongSynchronizer.isHeldExclusively()
         returns falseprotected final int getWaitQueueLength()
AbstractQueuedLongSynchronizer.getWaitQueueLength(java.util.concurrent.locks.AbstractQueuedLongSynchronizer.ConditionObject).IllegalMonitorStateException - if AbstractQueuedLongSynchronizer.isHeldExclusively()
         returns falseprotected final Collection<Thread> getWaitingThreads()
AbstractQueuedLongSynchronizer.getWaitingThreads(java.util.concurrent.locks.AbstractQueuedLongSynchronizer.ConditionObject).IllegalMonitorStateException - if AbstractQueuedLongSynchronizer.isHeldExclusively()
         returns false Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2015, Oracle and/or its affiliates.  All rights reserved.