19 |
|
* when used as a queue. |
20 |
|
* |
21 |
|
* <p>Most {@code ArrayDeque} operations run in amortized constant time. |
22 |
< |
* Exceptions include {@link #remove(Object) remove}, {@link |
23 |
< |
* #removeFirstOccurrence removeFirstOccurrence}, {@link #removeLastOccurrence |
24 |
< |
* removeLastOccurrence}, {@link #contains contains}, {@link #iterator |
25 |
< |
* iterator.remove()}, and the bulk operations, all of which run in linear |
26 |
< |
* time. |
22 |
> |
* Exceptions include |
23 |
> |
* {@link #remove(Object) remove}, |
24 |
> |
* {@link #removeFirstOccurrence removeFirstOccurrence}, |
25 |
> |
* {@link #removeLastOccurrence removeLastOccurrence}, |
26 |
> |
* {@link #contains contains}, |
27 |
> |
* {@link #iterator iterator.remove()}, |
28 |
> |
* and the bulk operations, all of which run in linear time. |
29 |
|
* |
30 |
< |
* <p>The iterators returned by this class's {@code iterator} method are |
31 |
< |
* <i>fail-fast</i>: If the deque is modified at any time after the iterator |
32 |
< |
* is created, in any way except through the iterator's own {@code remove} |
33 |
< |
* method, the iterator will generally throw a {@link |
30 |
> |
* <p>The iterators returned by this class's {@link #iterator() iterator} |
31 |
> |
* method are <em>fail-fast</em>: If the deque is modified at any time after |
32 |
> |
* the iterator is created, in any way except through the iterator's own |
33 |
> |
* {@code remove} method, the iterator will generally throw a {@link |
34 |
|
* ConcurrentModificationException}. Thus, in the face of concurrent |
35 |
|
* modification, the iterator fails quickly and cleanly, rather than risking |
36 |
|
* arbitrary, non-deterministic behavior at an undetermined time in the |