Class LinkedBlockingDeque<E>
- java.lang.Object
-
- java.util.AbstractCollection<E>
-
- java.util.AbstractQueue<E>
-
- org.datanucleus.store.rdbms.datasource.dbcp2.pool2.impl.LinkedBlockingDeque<E>
-
- Type Parameters:
E- the type of elements held in this collection Note: This was copied from Apache Harmony and modified to suit the needs of Commons Pool.
- All Implemented Interfaces:
java.io.Serializable,java.lang.Iterable<E>,java.util.Collection<E>,java.util.Deque<E>,java.util.Queue<E>
class LinkedBlockingDeque<E> extends java.util.AbstractQueue<E> implements java.util.Deque<E>, java.io.SerializableAn optionally-bounded blocking deque based on linked nodes.The optional capacity bound constructor argument serves as a way to prevent excessive expansion. The capacity, if unspecified, is equal to
Integer.MAX_VALUE. Linked nodes are dynamically created upon each insertion unless this would bring the deque above capacity.Most operations run in constant time (ignoring time spent blocking). Exceptions include
remove,removeFirstOccurrence,removeLastOccurrence,contains,iterator.remove(), and the bulk operations, all of which run in linear time.This class and its iterator implement all of the optional methods of the
CollectionandIteratorinterfaces.This class is a member of the Java Collections Framework.
- Since:
- 2.0
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private classLinkedBlockingDeque.AbstractItrBase class for Iterators for LinkedBlockingDequeprivate classLinkedBlockingDeque.DescendingItrDescending iteratorprivate classLinkedBlockingDeque.ItrForward iteratorprivate static classLinkedBlockingDeque.Node<E>Doubly-linked list node class.
-
Field Summary
Fields Modifier and Type Field Description private intcapacityMaximum number of items in the dequeprivate intcountNumber of items in the dequeprivate LinkedBlockingDeque.Node<E>firstPointer to first node.private LinkedBlockingDeque.Node<E>lastPointer to last node.private InterruptibleReentrantLocklockMain lock guarding all accessprivate java.util.concurrent.locks.ConditionnotEmptyCondition for waiting takesprivate java.util.concurrent.locks.ConditionnotFullCondition for waiting putsprivate static longserialVersionUID
-
Constructor Summary
Constructors Constructor Description LinkedBlockingDeque()Creates aLinkedBlockingDequewith a capacity ofInteger.MAX_VALUE.LinkedBlockingDeque(boolean fairness)Creates aLinkedBlockingDequewith a capacity ofInteger.MAX_VALUEand the given fairness policy.LinkedBlockingDeque(int capacity)Creates aLinkedBlockingDequewith the given (fixed) capacity.LinkedBlockingDeque(int capacity, boolean fairness)Creates aLinkedBlockingDequewith the given (fixed) capacity and fairness policy.LinkedBlockingDeque(java.util.Collection<? extends E> c)Creates aLinkedBlockingDequewith a capacity ofInteger.MAX_VALUE, initially containing the elements of the given collection, added in traversal order of the collection's iterator.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanadd(E e)voidaddFirst(E e)voidaddLast(E e)voidclear()Atomically removes all of the elements from this deque.booleancontains(java.lang.Object o)Returnstrueif this deque contains the specified element.java.util.Iterator<E>descendingIterator()intdrainTo(java.util.Collection<? super E> c)Drains the queue to the specified collection.intdrainTo(java.util.Collection<? super E> c, int maxElements)Drains no more than the specified number of elements from the queue to the specified collection.Eelement()Retrieves, but does not remove, the head of the queue represented by this deque.EgetFirst()EgetLast()intgetTakeQueueLength()Returns the length of the queue of threads waiting to take instances from this deque.booleanhasTakeWaiters()Returns true if there are threads waiting to take instances from this deque.voidinteruptTakeWaiters()Interrupts the threads currently waiting to take an object from the pool.java.util.Iterator<E>iterator()Returns an iterator over the elements in this deque in proper sequence.private booleanlinkFirst(E e)Links provided element as first element, or returns false if full.private booleanlinkLast(E e)Links provided element as last element, or returns false if full.booleanoffer(E e)booleanoffer(E e, long timeout, java.util.concurrent.TimeUnit unit)Links the provided element as the last in the queue, waiting up to the specified time to do so if the queue is full.booleanofferFirst(E e)booleanofferFirst(E e, long timeout, java.util.concurrent.TimeUnit unit)Links the provided element as the first in the queue, waiting up to the specified time to do so if the queue is full.booleanofferLast(E e)booleanofferLast(E e, long timeout, java.util.concurrent.TimeUnit unit)Links the provided element as the last in the queue, waiting up to the specified time to do so if the queue is full.Epeek()EpeekFirst()EpeekLast()Epoll()Epoll(long timeout, java.util.concurrent.TimeUnit unit)Unlinks the first element in the queue, waiting up to the specified time to do so if the queue is empty.EpollFirst()EpollFirst(long timeout, java.util.concurrent.TimeUnit unit)Unlinks the first element in the queue, waiting up to the specified time to do so if the queue is empty.EpollLast()EpollLast(long timeout, java.util.concurrent.TimeUnit unit)Unlinks the last element in the queue, waiting up to the specified time to do so if the queue is empty.Epop()voidpush(E e)voidput(E e)Links the provided element as the last in the queue, waiting until there is space to do so if the queue is full.voidputFirst(E e)Links the provided element as the first in the queue, waiting until there is space to do so if the queue is full.voidputLast(E e)Links the provided element as the last in the queue, waiting until there is space to do so if the queue is full.private voidreadObject(java.io.ObjectInputStream s)Reconstitutes this deque from a stream (that is, deserialize it).intremainingCapacity()Returns the number of additional elements that this deque can ideally (in the absence of memory or resource constraints) accept without blocking.Eremove()Retrieves and removes the head of the queue represented by this deque.booleanremove(java.lang.Object o)Removes the first occurrence of the specified element from this deque.EremoveFirst()booleanremoveFirstOccurrence(java.lang.Object o)EremoveLast()booleanremoveLastOccurrence(java.lang.Object o)intsize()Returns the number of elements in this deque.Etake()Unlinks the first element in the queue, waiting until there is an element to unlink if the queue is empty.EtakeFirst()Unlinks the first element in the queue, waiting until there is an element to unlink if the queue is empty.EtakeLast()Unlinks the last element in the queue, waiting until there is an element to unlink if the queue is empty.java.lang.Object[]toArray()Returns an array containing all of the elements in this deque, in proper sequence (from first to last element).<T> T[]toArray(T[] a)java.lang.StringtoString()private voidunlink(LinkedBlockingDeque.Node<E> x)Unlinks the provided node.private EunlinkFirst()Removes and returns the first element, or null if empty.private EunlinkLast()Removes and returns the last element, or null if empty.private voidwriteObject(java.io.ObjectOutputStream s)Saves the state of this deque to a stream (that is, serialize it).-
Methods inherited from class java.util.AbstractCollection
containsAll, isEmpty, removeAll, retainAll
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
-
-
-
Field Detail
-
serialVersionUID
private static final long serialVersionUID
- See Also:
- Constant Field Values
-
first
private transient LinkedBlockingDeque.Node<E> first
Pointer to first node. Invariant: (first == null && last == null) || (first.prev == null && first.item != null)
-
last
private transient LinkedBlockingDeque.Node<E> last
Pointer to last node. Invariant: (first == null && last == null) || (last.next == null && last.item != null)
-
count
private transient int count
Number of items in the deque
-
capacity
private final int capacity
Maximum number of items in the deque
-
lock
private final InterruptibleReentrantLock lock
Main lock guarding all access
-
notEmpty
private final java.util.concurrent.locks.Condition notEmpty
Condition for waiting takes
-
notFull
private final java.util.concurrent.locks.Condition notFull
Condition for waiting puts
-
-
Constructor Detail
-
LinkedBlockingDeque
public LinkedBlockingDeque()
Creates aLinkedBlockingDequewith a capacity ofInteger.MAX_VALUE.
-
LinkedBlockingDeque
public LinkedBlockingDeque(boolean fairness)
Creates aLinkedBlockingDequewith a capacity ofInteger.MAX_VALUEand the given fairness policy.- Parameters:
fairness- true means threads waiting on the deque should be served as if waiting in a FIFO request queue
-
LinkedBlockingDeque
public LinkedBlockingDeque(int capacity)
Creates aLinkedBlockingDequewith the given (fixed) capacity.- Parameters:
capacity- the capacity of this deque- Throws:
java.lang.IllegalArgumentException- ifcapacityis less than 1
-
LinkedBlockingDeque
public LinkedBlockingDeque(int capacity, boolean fairness)Creates aLinkedBlockingDequewith the given (fixed) capacity and fairness policy.- Parameters:
capacity- the capacity of this dequefairness- true means threads waiting on the deque should be served as if waiting in a FIFO request queue- Throws:
java.lang.IllegalArgumentException- ifcapacityis less than 1
-
LinkedBlockingDeque
public LinkedBlockingDeque(java.util.Collection<? extends E> c)
Creates aLinkedBlockingDequewith a capacity ofInteger.MAX_VALUE, initially containing the elements of the given collection, added in traversal order of the collection's iterator.- Parameters:
c- the collection of elements to initially contain- Throws:
java.lang.NullPointerException- if the specified collection or any of its elements are null
-
-
Method Detail
-
linkFirst
private boolean linkFirst(E e)
Links provided element as first element, or returns false if full.- Parameters:
e- The element to link as the first element.- Returns:
trueif successful, otherwisefalse
-
linkLast
private boolean linkLast(E e)
Links provided element as last element, or returns false if full.- Parameters:
e- The element to link as the last element.- Returns:
trueif successful, otherwisefalse
-
unlinkFirst
private E unlinkFirst()
Removes and returns the first element, or null if empty.- Returns:
- The first element or
nullif empty
-
unlinkLast
private E unlinkLast()
Removes and returns the last element, or null if empty.- Returns:
- The first element or
nullif empty
-
unlink
private void unlink(LinkedBlockingDeque.Node<E> x)
Unlinks the provided node.- Parameters:
x- The node to unlink
-
putFirst
public void putFirst(E e) throws java.lang.InterruptedException
Links the provided element as the first in the queue, waiting until there is space to do so if the queue is full.- Parameters:
e- element to link- Throws:
java.lang.NullPointerException- if e is nulljava.lang.InterruptedException- if the thread is interrupted whilst waiting for space
-
putLast
public void putLast(E e) throws java.lang.InterruptedException
Links the provided element as the last in the queue, waiting until there is space to do so if the queue is full.- Parameters:
e- element to link- Throws:
java.lang.NullPointerException- if e is nulljava.lang.InterruptedException- if the thread is interrupted whilst waiting for space
-
offerFirst
public boolean offerFirst(E e, long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedException
Links the provided element as the first in the queue, waiting up to the specified time to do so if the queue is full.- Parameters:
e- element to linktimeout- length of time to waitunit- units that timeout is expressed in- Returns:
trueif successful, otherwisefalse- Throws:
java.lang.NullPointerException- if e is nulljava.lang.InterruptedException- if the thread is interrupted whilst waiting for space
-
offerLast
public boolean offerLast(E e, long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedException
Links the provided element as the last in the queue, waiting up to the specified time to do so if the queue is full.- Parameters:
e- element to linktimeout- length of time to waitunit- units that timeout is expressed in- Returns:
trueif successful, otherwisefalse- Throws:
java.lang.NullPointerException- if e is nulljava.lang.InterruptedException- if the thread is interrupted whist waiting for space
-
takeFirst
public E takeFirst() throws java.lang.InterruptedException
Unlinks the first element in the queue, waiting until there is an element to unlink if the queue is empty.- Returns:
- the unlinked element
- Throws:
java.lang.InterruptedException- if the current thread is interrupted
-
takeLast
public E takeLast() throws java.lang.InterruptedException
Unlinks the last element in the queue, waiting until there is an element to unlink if the queue is empty.- Returns:
- the unlinked element
- Throws:
java.lang.InterruptedException- if the current thread is interrupted
-
pollFirst
public E pollFirst(long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedException
Unlinks the first element in the queue, waiting up to the specified time to do so if the queue is empty.- Parameters:
timeout- length of time to waitunit- units that timeout is expressed in- Returns:
- the unlinked element
- Throws:
java.lang.InterruptedException- if the current thread is interrupted
-
pollLast
public E pollLast(long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedException
Unlinks the last element in the queue, waiting up to the specified time to do so if the queue is empty.- Parameters:
timeout- length of time to waitunit- units that timeout is expressed in- Returns:
- the unlinked element
- Throws:
java.lang.InterruptedException- if the current thread is interrupted
-
removeFirstOccurrence
public boolean removeFirstOccurrence(java.lang.Object o)
- Specified by:
removeFirstOccurrencein interfacejava.util.Deque<E>
-
removeLastOccurrence
public boolean removeLastOccurrence(java.lang.Object o)
- Specified by:
removeLastOccurrencein interfacejava.util.Deque<E>
-
add
public boolean add(E e)
-
offer
public boolean offer(E e)
-
put
public void put(E e) throws java.lang.InterruptedException
Links the provided element as the last in the queue, waiting until there is space to do so if the queue is full.This method is equivalent to
putLast(Object).- Parameters:
e- element to link- Throws:
java.lang.NullPointerException- if e is nulljava.lang.InterruptedException- if the thread is interrupted whilst waiting for space
-
offer
public boolean offer(E e, long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedException
Links the provided element as the last in the queue, waiting up to the specified time to do so if the queue is full.This method is equivalent to
offerLast(Object, long, TimeUnit)- Parameters:
e- element to linktimeout- length of time to waitunit- units that timeout is expressed in- Returns:
trueif successful, otherwisefalse- Throws:
java.lang.NullPointerException- if e is nulljava.lang.InterruptedException- if the thread is interrupted whilst waiting for space
-
remove
public E remove()
Retrieves and removes the head of the queue represented by this deque. This method differs frompollonly in that it throws an exception if this deque is empty.This method is equivalent to
removeFirst.
-
poll
public E poll()
-
take
public E take() throws java.lang.InterruptedException
Unlinks the first element in the queue, waiting until there is an element to unlink if the queue is empty.This method is equivalent to
takeFirst().- Returns:
- the unlinked element
- Throws:
java.lang.InterruptedException- if the current thread is interrupted
-
poll
public E poll(long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedException
Unlinks the first element in the queue, waiting up to the specified time to do so if the queue is empty.This method is equivalent to
pollFirst(long, TimeUnit).- Parameters:
timeout- length of time to waitunit- units that timeout is expressed in- Returns:
- the unlinked element
- Throws:
java.lang.InterruptedException- if the current thread is interrupted
-
element
public E element()
-
peek
public E peek()
-
remainingCapacity
public int remainingCapacity()
Returns the number of additional elements that this deque can ideally (in the absence of memory or resource constraints) accept without blocking. This is always equal to the initial capacity of this deque less the currentsizeof this deque.Note that you cannot always tell if an attempt to insert an element will succeed by inspecting
remainingCapacitybecause it may be the case that another thread is about to insert or remove an element.- Returns:
- The number of additional elements the queue is able to accept
-
drainTo
public int drainTo(java.util.Collection<? super E> c)
Drains the queue to the specified collection.- Parameters:
c- The collection to add the elements to- Returns:
- number of elements added to the collection
- Throws:
java.lang.UnsupportedOperationException- if the add operation is not supported by the specified collectionjava.lang.ClassCastException- if the class of the elements held by this collection prevents them from being added to the specified collectionjava.lang.NullPointerException- if c is nulljava.lang.IllegalArgumentException- if c is this instance
-
drainTo
public int drainTo(java.util.Collection<? super E> c, int maxElements)
Drains no more than the specified number of elements from the queue to the specified collection.- Parameters:
c- collection to add the elements tomaxElements- maximum number of elements to remove from the queue- Returns:
- number of elements added to the collection
- Throws:
java.lang.UnsupportedOperationException- if the add operation is not supported by the specified collectionjava.lang.ClassCastException- if the class of the elements held by this collection prevents them from being added to the specified collectionjava.lang.NullPointerException- if c is nulljava.lang.IllegalArgumentException- if c is this instance
-
remove
public boolean remove(java.lang.Object o)
Removes the first occurrence of the specified element from this deque. If the deque does not contain the element, it is unchanged. More formally, removes the first elementesuch thato.equals(e)(if such an element exists). Returnstrueif this deque contained the specified element (or equivalently, if this deque changed as a result of the call).This method is equivalent to
removeFirstOccurrence.
-
size
public int size()
Returns the number of elements in this deque.
-
contains
public boolean contains(java.lang.Object o)
Returnstrueif this deque contains the specified element. More formally, returnstrueif and only if this deque contains at least one elementesuch thato.equals(e).- Specified by:
containsin interfacejava.util.Collection<E>- Specified by:
containsin interfacejava.util.Deque<E>- Overrides:
containsin classjava.util.AbstractCollection<E>- Parameters:
o- object to be checked for containment in this deque- Returns:
trueif this deque contains the specified element
-
toArray
public java.lang.Object[] toArray()
Returns an array containing all of the elements in this deque, in proper sequence (from first to last element).The returned array will be "safe" in that no references to it are maintained by this deque. (In other words, this method must allocate a new array). The caller is thus free to modify the returned array.
This method acts as bridge between array-based and collection-based APIs.
-
toArray
public <T> T[] toArray(T[] a)
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.util.AbstractCollection<E>
-
clear
public void clear()
Atomically removes all of the elements from this deque. The deque will be empty after this call returns.
-
iterator
public java.util.Iterator<E> iterator()
Returns an iterator over the elements in this deque in proper sequence. The elements will be returned in order from first (head) to last (tail). The returnedIteratoris a "weakly consistent" iterator that will never throwConcurrentModificationException, and guarantees to traverse elements as they existed upon construction of the iterator, and may (but is not guaranteed to) reflect any modifications subsequent to construction.- Specified by:
iteratorin interfacejava.util.Collection<E>- Specified by:
iteratorin interfacejava.util.Deque<E>- Specified by:
iteratorin interfacejava.lang.Iterable<E>- Specified by:
iteratorin classjava.util.AbstractCollection<E>- Returns:
- an iterator over the elements in this deque in proper sequence
-
descendingIterator
public java.util.Iterator<E> descendingIterator()
- Specified by:
descendingIteratorin interfacejava.util.Deque<E>
-
writeObject
private void writeObject(java.io.ObjectOutputStream s) throws java.io.IOExceptionSaves the state of this deque to a stream (that is, serialize it).- Parameters:
s- the stream- Throws:
java.io.IOException
-
readObject
private void readObject(java.io.ObjectInputStream s) throws java.io.IOException, java.lang.ClassNotFoundExceptionReconstitutes this deque from a stream (that is, deserialize it).- Parameters:
s- the stream- Throws:
java.io.IOExceptionjava.lang.ClassNotFoundException
-
hasTakeWaiters
public boolean hasTakeWaiters()
Returns true if there are threads waiting to take instances from this deque. See disclaimer on accuracy inReentrantLock.hasWaiters(Condition).- Returns:
- true if there is at least one thread waiting on this deque's notEmpty condition.
-
getTakeQueueLength
public int getTakeQueueLength()
Returns the length of the queue of threads waiting to take instances from this deque. See disclaimer on accuracy inReentrantLock.getWaitQueueLength(Condition).- Returns:
- number of threads waiting on this deque's notEmpty condition.
-
interuptTakeWaiters
public void interuptTakeWaiters()
Interrupts the threads currently waiting to take an object from the pool. See disclaimer on accuracy inReentrantLock.getWaitingThreads(Condition).
-
-