Interface Deque<E>
- All Superinterfaces:
Collection<E>, Iterable<E>, Queue<E>
- All Known Implementing Classes:
ArrayDeque, LinkedList
A kind of collection that can insert or remove element at both ends("double ended queue"). Mostly a deque has no limit of its size.
Extending from Queue, a deque can be used as a Queue which behavior is first-in-first-out. Furthermore, a deque can also be used as a Stack(legacy class) which behavior is last-in-first-out.
A typical deque does not allow null to be inserted as its element, while some implementations allow it. But null should not be inserted even in these implementations, since method poll return null to indicate that there is no element left in the deque.
A deque can also remove interior elements by removeFirstOccurrence and removeLastOccurrence methods. A deque can not access elements by index.
Type parameter E: the type of elements in this collection
Since
1.6
-
Method Summary
Modifier and TypeMethodDescriptionvoidInserts an element at the head of this deque if it dose not violate size limit immediately.voidInserts an element at the tail of this deque if it dose not violate size limit immediately.Returns the iterator in reverse order, from tail to head.getFirst()Gets but not removes the head element of this deque.getLast()Gets but not removes the tail element of this deque.booleanofferFirst(E e) Inserts an element at the head of this deque unless it would violate size limit.booleanInserts an element at the tail of this deque unless it would violate size limit.Gets but not removes the head element of this deque.peekLast()Gets but not removes the tail element of this deque.Gets and removes the head element of this deque.pollLast()Gets and removes the tail element of this deque.pop()Pops the head element of the deque, just same as removeFirst().voidPushes the element to the deque(at the head of the deque), just same as addFirst(E).Gets and removes the head element of this deque.booleanRemoves the first equivalent element of the specified object.Gets and removes the tail element of this deque.booleanRemoves the last equivalent element of the specified object.
-
Method Details
-
addFirst
Inserts an element at the head of this deque if it dose not violate size limit immediately. It is better to use offerFirst(E) if a deque is size-limited.
Parameters
e: the element
Throws
-
IllegalStateException: if it can not add now due to size limit -
ClassCastException: if the class of element can not be added into this deque -
NullPointerException: @throws NullPointerException if the element is null and the deque can not contain null element -
IllegalArgumentException: if the element can not be added due to some property.
-
addLast
Inserts an element at the tail of this deque if it dose not violate size limit immediately. It is better to use offerLast(E) if a deque is size-limited.
Parameters
e: the element
Throws
-
IllegalStateException: if it can not add now due to size limit -
ClassCastException: if the class of element can not be added into this deque -
NullPointerException: @throws NullPointerException if the element is null and the deque can not contain null element -
IllegalArgumentException: if the element can not be added due to some property.
-
offerFirst
Inserts an element at the head of this deque unless it would violate size limit. It is better than the addFirst(E) method in a size-limited deque, because the latter one may fail to add the element only by throwing an exception.
Parameters
e: the element
Returns
true if the operation succeeds or false if it fails.
Throws
-
ClassCastException: if the class of element can not be added into this deque -
NullPointerException: @throws NullPointerException if the element is null and the deque can not contain null element -
IllegalArgumentException: if the element can not be added due to some property.
-
offerLast
Inserts an element at the tail of this deque unless it would violate size limit. It is better than the addLast(E) method in a size-limited deque, because the latter one may fail to add the element only by throwing an exception.
Parameters
e: the element
Returns
true if the operation succeeds or false if it fails
Throws
-
ClassCastException: if the class of element can not be added into this deque -
NullPointerException: @throws NullPointerException if the element is null and the deque can not contain null element -
IllegalArgumentException: if the element can not be added due to some property
-
removeFirst
E removeFirst()Gets and removes the head element of this deque. This method throws an exception if the deque is empty.
Returns
the head element
Throws
NoSuchElementException: if the deque is empty
-
removeLast
E removeLast()Gets and removes the tail element of this deque. This method throws an exception if the deque is empty.
Returns
the tail element
Throws
NoSuchElementException: if the deque is empty
-
pollFirst
E pollFirst()Gets and removes the head element of this deque. This method returns null if the deque is empty.
Returns
the head element or null if the deque is empty
-
pollLast
E pollLast()Gets and removes the tail element of this deque. This method returns null if the deque is empty.
Returns
the tail element or null if the deque is empty
-
getFirst
E getFirst()Gets but not removes the head element of this deque. This method throws an exception if the deque is empty.
Returns
the head element
Throws
NoSuchElementException: if the deque is empty
-
getLast
E getLast()Gets but not removes the tail element of this deque. This method throws an exception if the deque is empty.
Returns
the tail element
Throws
NoSuchElementException: if the deque is empty
-
peekFirst
E peekFirst()Gets but not removes the head element of this deque. This method returns null if the deque is empty.
Returns
the head element or null if the deque is empty
-
peekLast
E peekLast()Gets but not removes the tail element of this deque. This method returns null if the deque is empty.
Returns
the tail element or null if the deque is empty
-
removeFirstOccurrence
Removes the first equivalent element of the specified object. If the deque does not contain the element, it is unchanged and returns false.
Parameters
o: the element to be removed
Returns
- Returns:
true if the operation succeeds or false if the deque does not contain the element.
Throws
-
ClassCastException: if the class of the element is incompatible with the deque -
NullPointerException: @throws NullPointerException if the element is null and the deque can not contain null element
-
-
removeLastOccurrence
Removes the last equivalent element of the specified object. If the deque does not contain the element, it is unchanged and returns false.
Parameters
o: the element to be removed
Returns
- Returns:
true if the operation succeeds or false if the deque does not contain the element.
Throws
-
ClassCastException: if the class of the element is incompatible with the deque -
NullPointerException: @throws NullPointerException if the element is null and the deque can not contain null element
-
-
push
Pushes the element to the deque(at the head of the deque), just same as addFirst(E).
Parameters
e: the element
Throws
-
IllegalStateException: if it can not add now due to size limit -
ClassCastException: if the class of element can not be added into this deque -
NullPointerException: @throws NullPointerException if the element is null and the deque can not contain null element -
IllegalArgumentException: if the element can not be added due to some property.
-
pop
E pop()Pops the head element of the deque, just same as removeFirst().
Returns
the head element
Throws
NoSuchElementException: if the deque is empty
-
descendingIterator
-