API Reference > bentleyjs-core > Collections > PriorityQueue PriorityQueue<T> Class A priority queue implemented as a heap array. The queue is ordered by an OrderedComparator function supplied by the user such that the value in the queue that compares less than all other values is always located at the front of the queue. Implements Iterable<T> Methods Name Description constructor<T>(compare: OrderedComparator<T, T>, clone: CloneFunction<T> = shallowClone): PriorityQueue<T> Constructor [iterator](): Iterator<T, any, undefined> Returns an iterator over the contents of the heap suitable for use in for-of loops. _heapify(index: number): void Protected _peek(index: number): undefined | T Protected Returns the value at the specified index in the queue. _pop(index: number): undefined | T Protected Removes the value at the specified index from the queue and reorders the queue. _swap(a: number, b: number): void Protected append(value: T): T Pushes a value onto the back of the queue without making any attempt to enforce ordering. clear(): void Removes all values from the queue. pop(): undefined | T Removes the front-most element off of the queue and returns it. push(value: T): T Pushes a value onto the queue according to the sorting criterion. sort(): void Reorders the queue. Properties Name Type Description _array Protected T[] _clone ProtectedReadonly CloneFunction<T> _compare ProtectedReadonly OrderedComparator<T, T> front Accessor ReadOnly undefined | T Returns the element at the front of the queue, or undefined if the queue is empty. isEmpty Accessor ReadOnly boolean Returns true if the queue contains no values. length Accessor ReadOnly number The number of values in the queue. Defined in core/bentley/src/PriorityQueue.ts Line 20 Last Updated: 12 June, 2024