Class PriorityQueue<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractQueue<E>
java.util.PriorityQueue<E>
- All Implemented Interfaces:
Iterable<E>, Collection<E>, Queue<E>
A PriorityQueue holds elements on a priority heap, which orders the elements
according to their natural order or according to the comparator specified at
construction time. If the queue uses natural ordering, only elements that are
comparable are permitted to be inserted into the queue.
The least element of the specified ordering is stored at the head of the queue and the greatest element is stored at the tail of the queue.
A PriorityQueue is not synchronized. If multiple threads will have to access
it concurrently, use the PriorityBlockingQueue.
-
Constructor Summary
ConstructorsConstructorDescriptionConstructs a priority queue with an initial capacity of 11 and natural ordering.PriorityQueue(int initialCapacity) Constructs a priority queue with the specified capacity and natural ordering.PriorityQueue(int initialCapacity, Comparator<? super E> comparator) Constructs a priority queue with the specified capacity and comparator.PriorityQueue(Collection<? extends E> c) Constructs a priority queue that contains the elements of a collection.PriorityQueue(PriorityQueue<? extends E> c) Constructs a priority queue that contains the elements of another priority queue.PriorityQueue(SortedSet<? extends E> c) Constructs a priority queue that contains the elements of a sorted set. -
Method Summary
Modifier and TypeMethodDescriptionbooleanAdds the specified object to the priority queue.voidclear()Removes all the elements of the priority queue.Comparator<? super E> Gets the comparator of the priority queue.booleanAnswers if there is an element in this queue equals to the object.iterator()Gets the iterator of the priority queue, which will not return elements in any specified ordering.booleanInserts the element to the priority queue.peek()Gets but does not remove the head of the queue.poll()Gets and removes the head of the queue.booleanRemoves the specified object from the priority queue.intsize()Gets the size of the priority queue.Object[]toArray()Returns all the elements in an array.<T> T[]toArray(T[] array) Returns all the elements in an array, and the type of the result array is the type of the argument array.Methods inherited from class AbstractQueue
addAll, element, removeMethods inherited from class AbstractCollection
containsAll, isEmpty, removeAll, retainAll, toStringModifier and TypeMethodDescriptionbooleancontainsAll(Collection<?> collection) Tests whether thisCollectioncontains all objects contained in the specifiedCollection.booleanisEmpty()Returns if thisCollectioncontains no elements.booleanremoveAll(Collection<?> collection) Removes all occurrences in thisCollectionof each object in the specifiedCollection(optional).booleanretainAll(Collection<?> collection) Removes all objects from thisCollectionthat are not also found in theCollectionpassed (optional).toString()Returns the string representation of thisCollection.Methods inherited from class Object
clone, equals, getClass, hashCode, notify, notifyAll, wait, wait, waitModifier and TypeMethodDescriptionprotected Objectclone()booleanIndicates whether some other object is "equal to" this one.final ClassgetClass()Returns the runtime class of an object.inthashCode()Returns a hash code value for the object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.final voidwait()Causes current thread to wait until another thread invokes the method or the method for this object.final voidwait(long timeout) Causes current thread to wait until either another thread invokes the method or the method for this object, or a specified amount of time has elapsed.final voidwait(long timeout, int nanos) Causes current thread to wait until another thread invokes the method or the method for this object, or some other thread interrupts the current thread, or a certain amount of real time has elapsed.Methods inherited from interface Collection
equals, hashCode
-
Constructor Details
-
PriorityQueue
public PriorityQueue()Constructs a priority queue with an initial capacity of 11 and natural ordering. -
PriorityQueue
public PriorityQueue(int initialCapacity) Constructs a priority queue with the specified capacity and natural ordering.- Parameters:
initialCapacity- the specified capacity.- Throws:
IllegalArgumentException- if the initialCapacity is less than 1.
-
PriorityQueue
Constructs a priority queue with the specified capacity and comparator.- Parameters:
initialCapacity- the specified capacity.comparator- the specified comparator. If it is null, the natural ordering will be used.- Throws:
IllegalArgumentException- if the initialCapacity is less than 1.
-
PriorityQueue
Constructs a priority queue that contains the elements of a collection. The constructed priority queue has the initial capacity of 110% of the size of the collection. The queue uses natural ordering to order its elements.- Parameters:
c- the collection whose elements will be added to the priority queue to be constructed.- Throws:
ClassCastException- if any of the elements in the collection are not comparable.NullPointerException- if any of the elements in the collection are null.
-
PriorityQueue
Constructs a priority queue that contains the elements of another priority queue. The constructed priority queue has the initial capacity of 110% of the specified one. Both priority queues have the same comparator.- Parameters:
c- the priority queue whose elements will be added to the priority queue to be constructed.
-
PriorityQueue
Constructs a priority queue that contains the elements of a sorted set. The constructed priority queue has the initial capacity of 110% of the size of the sorted set. The priority queue will have the same comparator as the sorted set.- Parameters:
c- the sorted set whose elements will be added to the priority queue to be constructed.
-
-
Method Details
-
iterator
Gets the iterator of the priority queue, which will not return elements in any specified ordering.- Specified by:
iteratorin interfaceCollection<E>- Specified by:
iteratorin interfaceIterable<E>- Specified by:
iteratorin classAbstractCollection<E>- Returns:
- the iterator of the priority queue.
-
size
public int size()Gets the size of the priority queue. If the size of the queue is greater than the Integer.MAX, then it returns Integer.MAX.- Specified by:
sizein interfaceCollection<E>- Specified by:
sizein classAbstractCollection<E>- Returns:
- the size of the priority queue.
-
clear
public void clear()Removes all the elements of the priority queue.- Specified by:
clearin interfaceCollection<E>- Overrides:
clearin classAbstractQueue<E>- See Also:
-
offer
Inserts the element to the priority queue.- Parameters:
o- the element to add to the priority queue.- Returns:
- always true
- Throws:
ClassCastException- if the element cannot be compared with the elements in the priority queue using the ordering of the priority queue.NullPointerException- ifoisnull.
-
poll
Gets and removes the head of the queue.- Returns:
- the head of the queue or null if the queue is empty.
-
peek
Gets but does not remove the head of the queue.- Returns:
- the head of the queue or null if the queue is empty.
-
comparator
Gets the comparator of the priority queue.- Returns:
- the comparator of the priority queue or null if the natural ordering is used.
-
remove
Removes the specified object from the priority queue.- Specified by:
removein interfaceCollection<E>- Overrides:
removein classAbstractCollection<E>- Parameters:
o- the object to be removed.- Returns:
- true if the object was in the priority queue, false if the object was not in the priority queue.
-
add
Adds the specified object to the priority queue.- Specified by:
addin interfaceCollection<E>- Overrides:
addin classAbstractQueue<E>- Parameters:
o- the object to be added.- Returns:
- always true.
- Throws:
ClassCastException- if the element cannot be compared with the elements in the priority queue using the ordering of the priority queue.NullPointerException- ifoisnull.
-
contains
Answers if there is an element in this queue equals to the object.- Specified by:
containsin interfaceCollection<E>- Overrides:
containsin classAbstractCollection<E>- Parameters:
object- the object to search for.- Returns:
trueif object is an element of thisCollection,falseotherwise.- See Also:
-
toArray
Returns all the elements in an array. The result is a copy of all the elements.- Specified by:
toArrayin interfaceCollection<E>- Overrides:
toArrayin classAbstractCollection<E>- Returns:
- the Array of all the elements
- See Also:
-
toArray
public <T> T[] toArray(T[] array) Returns all the elements in an array, and the type of the result array is the type of the argument array. If the argument array is big enough, the elements from the queue will be stored in it(element immediately following the end of the queue is set to null, if any); otherwise, it will return a new array with the size of the argument array and size of the queue.- Specified by:
toArrayin interfaceCollection<E>- Overrides:
toArrayin classAbstractCollection<E>- Type Parameters:
T- the type of elements in the array- Parameters:
array- the array stores all the elements from the queue, if it has enough space; otherwise, a new array of the same type and the size of the queue will be used- Returns:
- the Array of all the elements
- Throws:
ArrayStoreException- if the type of the argument array is not compatible with every element in the queueNullPointerException- if the argument array is null- See Also:
-