 
 is new.
 is new. 
 java.lang.Objectjava.util.AbstractCollection<E>
java.util.AbstractQueue<E>
java.util.concurrent.PriorityBlockingQueue<E>
public class PriorityBlockingQueue<E>
An unbounded 
blocking queue
 that uses the same ordering rules as class 
PriorityQueue
 and supplies blocking retrieval operations.  While this queue is logically unbounded, attempted additions may fail due to resource exhaustion (causing 
OutOfMemoryError
). This class does not permit 
null
elements. A priority queue relying on 
 natural ordering
natural ordering
 
natural ordering 
also does not permit insertion of non-comparable objects (doing so results in 
ClassCastException
). 
This class and its iterator implement all of the optional methods of the 
Collection
 and 
Iterator
 interfaces.  The Iterator provided in method 
iterator()
 is not guaranteed to traverse the elements of the PriorityBlockingQueue in any particular order. If you need ordered traversal, consider using 
Arrays.sort(pq.toArray())
. 
 Also, method
Also, method 
 drainTo
drainTo 
 can be used to remove some or all elements in priority order and place them in another collection.
can be used to remove some or all elements in priority order and place them in another collection. 
 Operations on this class make no guarantees about the ordering of elements with equal priority. If you need to enforce an ordering, you can define custom classes or comparators that use a secondary key to break ties in primary priority values. For example, here is a class that applies first-in-first-out tie-breaking to comparable elements. To use it, you would insert a
Operations on this class make no guarantees about the ordering of elements with equal priority. If you need to enforce an ordering, you can define custom classes or comparators that use a secondary key to break ties in primary priority values. For example, here is a class that applies first-in-first-out tie-breaking to comparable elements. To use it, you would insert a 
 new FIFOEntry(anEntry)
new FIFOEntry(anEntry) 
 instead of a plain entry object.
instead of a plain entry object. 
class FIFOEntry<E extends Comparable<? super E>> implements Comparable<FIFOEntry<E>> { final static AtomicLong seq = new AtomicLong(); final long seqNum; final E entry; public FIFOEntry(E entry) { seqNum = seq.getAndIncrement(); this.entry = entry; } public E getEntry() { return entry; } public int compareTo(FIFOEntry<E> other) { int res = entry.compareTo(other.entry); if (res == 0 && other.entry != this.entry) res = (seqNum < other.seqNum ? -1 : 1); return res; } }
This class is a member of the Java Collections Framework .
| Constructor Summary | |
|---|---|
| PriorityBlockingQueue
() Creates a PriorityBlockingQueue with the default initial capacity (11) that orders its elements according to their  natural ordering       | |
| PriorityBlockingQueue
(
Collection
<? extends 
E
> c) Creates a PriorityBlockingQueue containing the elements in the specified collection. | |
| PriorityBlockingQueue
(int initialCapacity) Creates a PriorityBlockingQueue with the specified initial capacity that orders its elements according to their  natural ordering       | |
| PriorityBlockingQueue
(int initialCapacity,                      
Comparator
<? super 
E
> comparator) Creates a PriorityBlockingQueue with the specified initial capacity that orders its elements according to the specified comparator. | |
| Method Summary | ||
|---|---|---|
| boolean | add
( 
E  Inserts    into    priority 
queue. | |
| void | clear
() Atomically removes all of the elements from this queue. | |
| Comparator <? super E | comparator
() Returns the comparator used to order  the elements in 
this  queue,    queue uses the  natural ordering       | |
| boolean | contains
( 
Object Returns true if this  queue   | |
| int | drainTo
( 
Collection
<? super 
E Removes all available elements from this queue and adds them  to   | |
| int | drainTo
( 
Collection
<? super 
E Removes at most the given number of available elements from this queue and adds them  to   | |
| Iterator < E > | iterator
() Returns an iterator over the elements in this queue. | |
| boolean | offer
( 
E Inserts the specified element into this priority queue. | |
| boolean | offer
( 
E  e,   Inserts the specified element into this priority queue. | |
| E | peek
() Retrieves, but does not remove, the head of this queue,  or returns   | |
| E | poll
() Retrieves and removes the head of this queue, or  returns 
null 
if this queue is empty. | |
| E | poll
(long timeout, 
TimeUnit Retrieves and removes the head of this queue, waiting    necessary for an element to become available.   | |
| void | put
( 
E  Inserts    into   | |
| int | remainingCapacity
() Always returns Integer.MAX_VALUE because a PriorityBlockingQueue is not capacity constrained. | |
| boolean | remove
(
Object
 o) Removes a single instance of the specified element from this queue, if it is present. | |
| int | size
() Returns the number of elements in this collection. | |
| E | take
() Retrieves and removes the head of this queue, waiting if  necessary until an element becomes available.   | |
| Object | toArray
() Returns an array containing all of the elements in this  queue.   | |
| 
 | toArray
(T[] a) Returns an array containing all of the elements in this  queue;   | |
| String | toString
() Returns a string representation of this collection. | |
| Methods inherited from class java.util. AbstractQueue | 
|---|
| addAll , element , remove | 
| 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 | 
| Methods inherited from interface java.util. Queue | 
|---|
| element , remove | 
| Methods inherited from interface java.util. Collection | 
|---|
| addAll , containsAll , equals , hashCode , isEmpty , removeAll , retainAll | 
| Constructor Detail | 
|---|
public PriorityBlockingQueue()
 natural ordering
natural ordering
 .
. 
 
 
 
public PriorityBlockingQueue(int initialCapacity)
 natural ordering
natural ordering
 .
. 
 
 
 
 queue
queue 
 
public PriorityBlockingQueue(int initialCapacity,
                             Comparator<? super E> comparator)
 queue
queue 
 
public PriorityBlockingQueue(Collection<? extends E> c)
 the
the 
 
 ordering of its elements
ordering of its elements 
 
 the
the 
 
 ordering of its elements.
ordering of its elements. 
 
 the
the 
 
 ordering of its elements.
ordering of its elements. 
 
 - if the specified collection or any of its elements are null
- if the specified collection or any of its elements are null 
 
 
 
 
| Method Detail | 
|---|
public boolean add(Ee)
o)
 Inserts
Inserts 
 
 into
into 
 
 priority 
queue.
priority 
queue. 
 Specified by:
Specified by: 
 add
add
 in interface
in interface 
 Queue
Queue
 <
< 
 E
E
 >
> 
 e
e 
 
 (as specified by
(as specified by 
 Collection.add(E)
Collection.add(E)
 )
) 
 
 
 
 ClassCastException
ClassCastException
 
 - if the specified element cannot be compared with elements currently in the priority queue according to the priority queue's ordering
- if the specified element cannot be compared with elements currently in the priority queue according to the priority queue's ordering 
 
 
 
 NullPointerException
NullPointerException
 
 - if the specified element is null
- if the specified element is null 
 
 
 
 
 offer
offer 
 
public boolean
publicComparator<? superE>offer
comparator(
E
e)
()
 Inserts the specified element into this priority queue.
Inserts the specified element into this priority queue. 
 
 
 
 
 
 Specified by:
Specified by: 
 offer
offer
 in interface
in interface 
 BlockingQueue
BlockingQueue
 <
< 
 E
E
 >
> 
 Specified by:
Specified by: 
 offer
offer
 in interface
in interface 
 Queue
Queue
 <
< 
 E
E
 >
> 
 Parameters:
Parameters: 
 e - the element to add
e - the element to add 
 
 true
true 
 
 (as specified by
(as specified by 
 Queue.offer(E)
Queue.offer(E)
 )
) 
 Throws:
Throws: 
 ClassCastException
ClassCastException
 - if the specified element cannot be compared with elements currently in the priority queue according to the priority queue's ordering
- if the specified element cannot be compared with elements currently in the priority queue according to the priority queue's ordering 
 NullPointerException
NullPointerException
 - if the specified element is null
- if the specified element is null 
 
 
 
 
 
 put
put 
 
publicvoid
booleanput
offer(Ee)
o)
 As the queue is unbounded this method will never block.
As the queue is unbounded this method will never block. 
 put
put
 
 
 
 
 
 
 
 
 e
e 
 
 
 
 ordering
ordering 
 
 
 
 
 
 
 offer
offer 
 
publicboolean
voidoffer
put(Ee, long timeout,
TimeUnit
unit)
o)
 Inserts
Inserts 
 
 into
into 
 
 offer
offer
 
 e - the element to add
e - the element to add 
 timeout - This parameter is ignored as the method never blocks
timeout - This parameter is ignored as the method never blocks 
 unit - This parameter is ignored as the method never blocks
unit - This parameter is ignored as the method never blocks 
 
 Returns:
Returns: 
 true
true 
 specified 
element cannot be compared with elements currently in the priority queue according to the priority queue's
specified 
element cannot be compared with elements currently in the priority queue according to the priority queue's 
 ordering
ordering 
 
 
 
 
 
 poll
poll 
 
public
E
public booleanpoll
offer()
(Eo, long timeout,TimeUnitunit)
 Description copied from interface:
Description copied from interface: 
 Queue
Queue
 Retrieves and removes the head of this queue, or returns
Retrieves and removes the head of this queue, or returns 
 null
null 
 if this queue is empty.
if this queue is empty. 
 
 poll
poll
 
 Queue
Queue
 
 
 
 
 
 the head of this queue, or
the head of this queue, or 
 
 
 
 
 
 
 if this queue is empty
if this queue is empty 
 
public E take()
       throws InterruptedException
 necessary until an element becomes available.
necessary until an element becomes available. 
 
 waiting
waiting 
 
 
 
public Epoll(long timeout,
TimeUnit
unit) throws
InterruptedException
()
 BlockingQueue
BlockingQueue
 
 Retrieves and removes the head of this queue, waiting up to the specified wait time if necessary for an element to become available.
Retrieves and removes the head of this queue, waiting up to the specified wait time if necessary for an element to become available. 
 
 
 
 poll
poll
 
 BlockingQueue
BlockingQueue
 
 Parameters:
Parameters: 
 timeout - how long to wait before giving up, in units of
timeout - how long to wait before giving up, in units of 
 unit
unit 
 unit - a
unit - a 
 TimeUnit
TimeUnit 
 determining how to interpret the
determining how to interpret the 
 timeout
timeout 
 parameter
parameter 
 if the specified waiting time elapses before an element is available
if the specified waiting time elapses before an element is available 
 Throws:
Throws: 
 InterruptedException
InterruptedException
 - if interrupted while waiting
- if interrupted while waiting 
 
 
 
 peek
peek 
 
public Epeek
poll()
(long timeout,TimeUnitunit) throwsInterruptedException
 Queue
Queue
 
 Retrieves, but does not remove, the head of this queue, or returns
Retrieves, but does not remove, the head of this queue, or returns 
 null
null 
 if this queue is empty.
if this queue is empty. 
 
 peek
peek
 
 Queue
Queue
 
 
 
 
 
 
 
 
 
 if this queue is empty
if this queue is empty 
 
 
 
 
 
 
 comparator
comparator 
 
publicComparator
E<? super
E
>
comparator
peek()
 Returns the comparator used to order the elements in this queue, or
Returns the comparator used to order the elements in this queue, or 
 
 
 
 if this queue uses the
if this queue uses the 
 natural ordering
natural ordering
 of its elements.
of its elements. 
 
 
 
 
 
 
 
 
 the comparator used to order the elements in this queue, or
the comparator used to order the elements in this queue, or 
 
 if this queue uses the natural ordering of its elements.
if this queue uses the natural ordering of its elements. 
 
public int size()
 interface:
interface: 
 Collection
Collection
 
 
 this
this 
 
 collection
collection 
 
public int remainingCapacity()
public boolean remove(Object o)
 More formally, removes an element
More formally, removes an element 
 e
e 
 such that
such that 
 o.equals(e)
o.equals(e) 
 , if this queue contains one or more such elements. Returns
, if this queue contains one or more such elements. Returns 
 true
true 
 if this queue contained the specified element (or equivalently, if this queue changed as a result of the call).
if this queue contained the specified element (or equivalently, if this queue changed as a result of the call). 
 Specified by:
Specified by: 
 remove
remove
 in interface
in interface 
 BlockingQueue
BlockingQueue
 <
< 
 E
E
 >
> 
 queue,
queue, 
 
 present
present 
 
 if this queue changed as a result of the call
if this queue changed as a result of the call 
 
public boolean contains(Object o)
 
 
 queue
queue 
 
 queue
queue 
 
 o.equals(e)
o.equals(e) 
 
 
This implementation iterates over the elements in the collection, checking each element in turn for equality with the specified element. 
 Specified by:
Specified by: 
 contains
contains
 in interface
in interface 
 BlockingQueue
BlockingQueue
 <
< 
 E
E
 >
> 
 queue
queue 
 
 queue
queue 
 
 element
element 
 
public Object[] toArray()
 
 
 queue. The
queue. The 
 
 array
array 
 
 are 
in
are 
in 
 no particular
no particular 
 
The returned array will be "safe" in that no references to it are maintained by 
 this queue.
this queue. 
 
the collection. 
(In other words, this method must allocate a new 
 array).
array). 
 
array even if the collection is backed by an Array). 
 The caller is thus free to modify the returned array. 
 This method acts as bridge between array-based and collection-based APIs.
This method acts as bridge between array-based and collection-based APIs. 
 
This implementation allocates the array to be returned, and iterates over the elements in the collection, storing each object reference in the next consecutive element of the array, starting with element 0. 
 queue
queue 
 
public String toString()
 String.valueOf(Object)
String.valueOf(Object)
 
 
This implementation creates an empty string buffer, appends a left square bracket, and iterates over the collection appending the string representation of each element in turn. After appending each element except the last, the string 
 
", " 
 
is appended. Finally a right bracket is appended. A string is obtained from the string buffer, and returned. 
 collection
collection 
 
public int drainTo(Collection<? super E> c)
 to
to 
 
 add elements to collection
add elements to collection 
 
 
 the number of elements transferred
the number of elements transferred 
 Throws:
Throws: 
 UnsupportedOperationException
UnsupportedOperationException
 - if addition of elements is not supported by the specified collection
- if addition of elements is not supported by the specified collection 
 ClassCastException
ClassCastException
 - if the class of an element of this queue prevents it from being added to the specified collection
- if the class of an element of this queue prevents it from being added to the specified collection 
 NullPointerException
NullPointerException
 - if the specified collection is null
- if the specified collection is null 
 IllegalArgumentException
IllegalArgumentException
 - if the specified collection is this queue, or some property of an element of this queue prevents it from being added to the specified collection
- if the specified collection is this queue, or some property of an element of this queue prevents it from being added to the specified collection 
 
public int drainTo(Collection<? super E> c,
                   int maxElements)
 to
to 
 
 add elements to collection
add elements to collection 
 
 
 the number of elements transferred
the number of elements transferred 
 Throws:
Throws: 
 UnsupportedOperationException
UnsupportedOperationException
 - if addition of elements is not supported by the specified collection
- if addition of elements is not supported by the specified collection 
 ClassCastException
ClassCastException
 - if the class of an element of this queue prevents it from being added to the specified collection
- if the class of an element of this queue prevents it from being added to the specified collection 
 NullPointerException
NullPointerException
 - if the specified collection is null
- if the specified collection is null 
 IllegalArgumentException
IllegalArgumentException
 - if the specified collection is this queue, or some property of an element of this queue prevents it from being added to the specified collection
- if the specified collection is this queue, or some property of an element of this queue prevents it from being added to the specified collection 
 
public void clear()
public <T> T[] toArray(T[] a)
 
 
 queue;
queue; 
 
 The returned array elements are in no particular order. 
If the
The returned array elements are in no particular order. 
If the 
 queue
queue 
 
 queue.
queue. 
 
If 
 this queue
this queue 
 
the collection 
fits in the specified array with room to spare (i.e., the array has more elements than 
 this queue), 
the
this queue), 
the 
 
collection), the 
element in the array immediately following the end of the 
 queue
queue 
 
collection 
is set to 
null
. 
 
This is useful in determining the length of the collection 
 
only 
 
if the caller knows that the collection does not contain any 
 
null 
 
elements.) 
 Like the
Like the 
 toArray()
toArray()
 method, this method acts as bridge between array-based and collection-based APIs. Further, this method allows precise control over the runtime type of the output array, and may, under certain circumstances, be used to save allocation costs.
method, this method acts as bridge between array-based and collection-based APIs. Further, this method allows precise control over the runtime type of the output array, and may, under certain circumstances, be used to save allocation costs. 
 
If this collection makes any guarantees as to what order its elements are returned by its iterator, this method must return the elements in the same order. 
 Suppose
Suppose 
 
This implementation checks if the array is large enough to contain the collection; if not, it allocates a new array of the correct size and type (using reflection). Then, it iterates over the collection, storing each object reference in the next consecutive element of the array, starting with element 0. If the array is larger than the collection, a 
 x
x 
 
null 
 is a queue known to contain only strings. The following code can be used to dump the queue into a newly allocated array of
is a queue known to contain only strings. The following code can be used to dump the queue into a newly allocated array of 
 String
String 
 :
: 
String[] y = x.toArray(new String[0]);
 Note that
Note that 
 toArray(new Object[0])
toArray(new Object[0]) 
 is identical in function to
is identical in function to 
 toArray()
toArray() 
 .
. 
 
 queue
queue 
 
 purpose
purpose 
 
 an array containing all of the elements in this queue
an array containing all of the elements in this queue 
 Throws:
Throws: 
 ArrayStoreException
ArrayStoreException
 - if the runtime type of the specified array is not a supertype of the runtime type of every element in this queue
- if the runtime type of the specified array is not a supertype of the runtime type of every element in this queue 
 NullPointerException
NullPointerException
 - if the specified array is null
- if the specified array is null 
 
public Iterator<E> iterator()
 queue
queue 
