E - このコレクション内に保持される要素の型public class ConcurrentLinkedDeque<E> extends AbstractCollection<E> implements Deque<E>, Serializable
ConcurrentLinkedDequeは選択肢として適切です。 大半のコレクション実装と同様、このクラスはnull要素の使用を許容しません。
イテレータおよびスプリッテレータは弱一貫性を持っています。
大半のコレクションとは異なり、sizeメソッドは一定時間のオペレーションではないことに留意してください。 これらの両端キューの非同期の性質のために、現在の要素の数を判定するには要素のトラバーサルが必要になります。そのため、このコレクションがトラバーサル中に変更された場合は、不正確な結果が報告される可能性があります。 また、addAll、removeAll、retainAll、containsAll、equals、およびtoArrayの一括オペレーションについて、原子的な実行は保証されていません。 たとえば、addAllオペレーションと並行して動作するイテレータは、追加された要素の一部しか表示しないことがあります。
このクラスとそのイテレータは、DequeおよびIteratorインタフェースの任意メソッドすべてを実装します。
メモリー整合性効果: ほかの並行処理コレクションと同様、オブジェクトをConcurrentLinkedDequeに配置する前のスレッド内のアクションは、別のスレッドでのその要素へのアクセスまたはConcurrentLinkedDequeからの削除に続くアクションよりも前に発生します。
このクラスは、Java Collections Frameworkのメンバーです。
| コンストラクタ | 説明 |
|---|---|
ConcurrentLinkedDeque() |
空の両端キューを構築します。
|
ConcurrentLinkedDeque(Collection<? extends E> c) |
指定されたコレクションの要素を初期状態で含む(要素はコレクションのイテレータのトラバーサル順に追加)両端キューを構築します。
|
| 修飾子と型 | メソッド | 説明 |
|---|---|---|
boolean |
add(E e) |
指定された要素をこの両端キューの末尾に挿入します。
|
boolean |
addAll(Collection<? extends E> c) |
指定されたコレクション内のすべての要素を、指定されたコレクションのイテレータによって返される順序でこの両端キューの最後に追加します。
|
void |
addFirst(E e) |
指定された要素をこの両端キューの先頭に挿入します。
|
void |
addLast(E e) |
指定された要素をこの両端キューの末尾に挿入します。
|
void |
clear() |
すべての要素を両端キューから削除します。
|
boolean |
contains(Object o) |
この両端キュー内に
o.equals(e)のような1つ以上の要素eが含まれている場合、trueを返します。 |
Iterator<E> |
descendingIterator() |
この両端キュー内の要素を逆順で反復処理するイテレータを返します。
|
E |
element() |
この両端キューによって表されるキューの先頭(つまり、この両端キューの最初の要素)を取得しますが、削除しません。
|
E |
getFirst() |
この両端キューの最初の要素を取得しますが、削除はしません。
|
E |
getLast() |
この両端キューの最後の要素を取得しますが、削除はしません。
|
boolean |
isEmpty() |
このコレクションに要素がない場合に
trueを返します。 |
Iterator<E> |
iterator() |
この両端キュー内の要素を適切な順序で反復処理するイテレータを返します。
|
boolean |
offer(E e) |
指定された要素をこの両端キューの末尾に挿入します。
|
boolean |
offerFirst(E e) |
指定された要素をこの両端キューの先頭に挿入します。
|
boolean |
offerLast(E e) |
指定された要素をこの両端キューの末尾に挿入します。
|
E |
peek() |
この両端キューによって表されるキューの先頭(つまり、この両端キューの最初の要素)を取得しますが、削除しません。両端キューが空の場合は、
nullを返します。 |
E |
peekFirst() |
この両端キューの最初の要素を取得しますが、削除しません。両端キューが空の場合は
nullを返します。 |
E |
peekLast() |
この両端キューの最後の要素を取得しますが、削除しません。両端キューが空の場合は
nullを返します。 |
E |
poll() |
この両端キューによって表されるキューの先頭(つまり、この両端キューの最初の要素)を取得および削除します。両端キューが空の場合は、
nullを返します。 |
E |
pollFirst() |
この両端キューの最初の要素を取得および削除します。両端キューが空の場合は
nullを返します。 |
E |
pollLast() |
この両端キューの最後の要素を取得および削除します。両端キューが空の場合は
nullを返します。 |
E |
pop() |
この両端キューで表されるスタックに要素をポップします。
|
void |
push(E e) |
容量制限に違反することなしに要素をこの両端キューで表されるスタック(つまり、この両端キューの先頭)にすぐにプッシュできる場合は、そうします。使用可能な空き領域がその時点で存在しない場合は
IllegalStateExceptionをスローします。 |
E |
remove() |
この両端キューによって表されるキューの先頭(つまり、この両端キューの最初の要素)を取得して削除します。
|
boolean |
remove(Object o) |
o.equals(e)のような最初の要素eがこの両端キュー内に存在する場合、要素を削除します。 |
E |
removeFirst() |
この両端キューの最初の要素を取得して削除します。
|
boolean |
removeFirstOccurrence(Object o) |
o.equals(e)のような最初の要素eがこの両端キュー内に存在する場合、要素を削除します。 |
E |
removeLast() |
この両端キューの最後の要素を取得して削除します。
|
boolean |
removeLastOccurrence(Object o) |
o.equals(e)のような最後の要素eがこの両端キュー内に存在する場合、要素を削除します。 |
int |
size() |
この両端キュー内の要素の数を返します。
|
Spliterator<E> |
spliterator() |
この両端キュー内の要素に対する
Spliteratorを返します。 |
Object[] |
toArray() |
両端キュー内のすべての要素を適切な順序(最初の要素から最後の要素へ)で格納している配列を返します。
|
<T> T[] |
toArray(T[] a) |
両端キュー内のすべての要素を適切な順序(最初の要素から最後の要素へ)で格納している配列を返します。返される配列の実行時の型は、指定された配列の型になります。
|
containsAll, removeAll, retainAll, toStringclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitcontainsAll, equals, hashCode, parallelStream, removeAll, removeIf, retainAll, streampublic ConcurrentLinkedDeque()
public ConcurrentLinkedDeque(Collection<? extends E> c)
c - 初期状態で含む要素のコレクションNullPointerException - 指定されたコレクションまたはそのいずれかの要素がnullである場合public void addFirst(E e)
IllegalStateExceptionをスローしません。 addFirst、インタフェースDeque<E>e - 追加する要素NullPointerException - 指定された要素がnullである場合public void addLast(E e)
IllegalStateExceptionをスローしません。
このメソッドは、add(E)と同等です。
addLast、インタフェースDeque<E>e - 追加する要素NullPointerException - 指定された要素がnullである場合public boolean offerFirst(E e)
falseを返しません。 offerFirst、インタフェースDeque<E>e - 追加する要素true (Deque.offerFirst(E)で指定されているとおり)NullPointerException - 指定された要素がnullである場合public boolean offerLast(E e)
offerLast、インタフェースDeque<E>e - 追加する要素true (Deque.offerLast(E)で指定されているとおり)NullPointerException - 指定された要素がnullである場合public E peekFirst()
Dequenullを返します。public E peekLast()
Dequenullを返します。public E getFirst()
DequepeekFirstメソッドと異なります。 getFirst、インタフェースDeque<E>NoSuchElementException - この両端キューが空の場合public E getLast()
DequepeekLastメソッドと異なります。 getLast、インタフェースDeque<E>NoSuchElementException - この両端キューが空の場合public E pollFirst()
Dequenullを返します。public E pollLast()
Dequenullを返します。public E removeFirst()
DequepollFirstメソッドと異なります。 removeFirst、インタフェースDeque<E>NoSuchElementException - この両端キューが空の場合public E removeLast()
DequepollLastメソッドと異なります。 removeLast、インタフェースDeque<E>NoSuchElementException - この両端キューが空の場合public boolean offer(E e)
falseを返しません。 offer、インタフェースDeque<E>offer、インタフェースQueue<E>e - 追加する要素true (Queue.offer(E)で指定されているとおり)NullPointerException - 指定された要素がnullである場合public boolean add(E e)
IllegalStateExceptionをスローしないか、またはfalseを返します。 add、インタフェースCollection<E>add、インタフェースDeque<E>add、インタフェースQueue<E>add、クラスAbstractCollection<E>e - このコレクションにあるかどうかを調べる要素true (Collection.add(E)で指定されているとおり)NullPointerException - 指定された要素がnullである場合public E poll()
Dequenullを返します。
このメソッドは、Deque.pollFirst()と同等です。
public E peek()
Dequenullを返します。
このメソッドは、Deque.peekFirst()と同等です。
public E remove()
Dequepollメソッドと異なります。
このメソッドは、Deque.removeFirst()と同等です。
public E pop()
Dequepop、インタフェースDeque<E>NoSuchElementException - この両端キューが空の場合public E element()
Dequepeekメソッドと異なります。
このメソッドは、Deque.getFirst()と同等です。
public void push(E e)
DequeIllegalStateExceptionをスローします。
このメソッドは、Deque.addFirst(E)と同等です。
push、インタフェースDeque<E>e - プッシュする要素NullPointerException - 指定された要素がnullで、この両端キューがnull要素を許可しない場合public boolean removeFirstOccurrence(Object o)
o.equals(e)のような最初の要素eがこの両端キュー内に存在する場合、要素を削除します。 その要素が両端キューにない場合、変更はありません。 removeFirstOccurrence、インタフェースDeque<E>o - この両端キューから削除される要素(その要素が存在する場合)trueNullPointerException - 指定された要素がnullである場合public boolean removeLastOccurrence(Object o)
o.equals(e)のような最後の要素eがこの両端キュー内に存在する場合、要素を削除します。 その要素が両端キューにない場合、変更はありません。 removeLastOccurrence、インタフェースDeque<E>o - この両端キューから削除される要素(その要素が存在する場合)trueNullPointerException - 指定された要素がnullである場合public boolean contains(Object o)
o.equals(e)のような1つ以上の要素eが含まれている場合、trueを返します。contains、インタフェースCollection<E>contains、インタフェースDeque<E>contains、クラスAbstractCollection<E>o - この両端キューにあるかどうかを調べる要素truepublic boolean isEmpty()
trueを返します。isEmpty、インタフェースCollection<E>isEmpty、クラスAbstractCollection<E>truepublic int size()
Integer.MAX_VALUEより多くの要素がある場合は、Integer.MAX_VALUEを返します。
大半のコレクションとは異なり、このメソッドは一定時間のオペレーションではないことに留意してください。 これらの両端キューの非同期の性質のために、現在の要素の数を判定するには、そのすべてをトラバースしてカウントすることが必要になります。 また、このメソッドの実行中にサイズが変更される可能性もあり、その場合、返される値は不正確になります。 そのため、このメソッドは、通常は並行処理アプリケーションではあまり便利ではありません。
size、インタフェースCollection<E>size、インタフェースDeque<E>size、クラスAbstractCollection<E>public boolean remove(Object o)
o.equals(e)のような最初の要素eがこの両端キュー内に存在する場合、要素を削除します。 その要素が両端キューにない場合、変更はありません。 remove、インタフェースCollection<E>remove、インタフェースDeque<E>remove、クラスAbstractCollection<E>o - この両端キューから削除される要素(その要素が存在する場合)trueNullPointerException - 指定された要素がnullである場合public boolean addAll(Collection<? extends E> c)
addAllしようとすると、IllegalArgumentExceptionが発生します。 addAll、インタフェースCollection<E>addAll、クラスAbstractCollection<E>c - この両端キューに挿入される要素trueNullPointerException - 指定されたコレクションまたはそのいずれかの要素がnullである場合IllegalArgumentException - コレクションがこの両端キューである場合AbstractCollection.add(Object)public void clear()
clear、インタフェースCollection<E>clear、クラスAbstractCollection<E>public Object[] toArray()
返される配列への参照を両端キューが維持しないという点で、この配列は安全です。 (つまり、このメソッドは新しい配列を割り当てます)。 このため、呼出し側は、返された配列を自由に変更できます。
このメソッドは、配列ベースのAPIとコレクションベースのAPIの間の橋渡し役として機能します。
toArray、インタフェースCollection<E>toArray、クラスAbstractCollection<E>public <T> T[] toArray(T[] a)
両端キューが指定された配列に収まり、その配列にさらに余裕がある場合(つまり、配列が両端キューより多くの要素を持つ場合)、その配列内で両端キューの終端よりあとの要素はnullに設定されます。
toArray()メソッドと同じように、このメソッドは、配列ベースのAPIとコレクションベースのAPIの間の橋渡し役として機能します。 さらに、このメソッドでは出力配列の実行時の型を正確に制御できるため、環境によっては割当ての手間を抑えるために使用できます。
xが、文字列だけからなる両端キューであることがわかっていると仮定します。 次のコードを使うと、新しく割り当てられたStringの配列に両端キューをダンプできます。
String[] y = x.toArray(new String[0]);
toArray(new Object[0])は、機能の点でtoArray()と同一です。toArray、インタフェースCollection<E>toArray、クラスAbstractCollection<E>T - コレクションを含む配列の実行時の型a - 配列が十分な大きさを持つ場合は、両端キューの要素が格納される配列。そうでない場合は、要素を格納するために同じ実行時の型の新しい配列が割り当てられるArrayStoreException - 指定された配列の実行時の型が、この両端キュー内のすべての要素の実行時の型のスーパー・タイプでない場合NullPointerException - 指定された配列がnullである場合public Iterator<E> descendingIterator()
descendingIterator、インタフェースDeque<E>public Spliterator<E> spliterator()
Spliteratorを返します。
返されるスプリッテレータは弱一貫性を保持します。
Spliteratorは、Spliterator.CONCURRENT、Spliterator.ORDEREDおよびSpliterator.NONNULLを報告します。
spliterator、インタフェースIterable<E>spliterator、インタフェースCollection<E>Spliteratorは、制限付きの並列処理を許可するためにtrySplitを実装します。Spliterator バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。 そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright © 1993, 2025, Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Documentation Redistribution Policyも参照してください。