E - このコレクション内に保持される要素の型public class CopyOnWriteArrayList<E> extends Object implements List<E>, RandomAccess, Cloneable, Serializable
、setなど)が実装される通常、これは非常に効率が悪いのですが、トラバーサル操作が変更を数の点で大幅に上回る場合には、代替手段よりも効率が良い場合があります。また、これは、トラバーサルを同期できない場合や、同期することを望まないが、並行スレッド間の干渉を排除する必要がある場合に有用です。 「スナップショット」スタイルのイテレータ・メソッドは、イテレータの作成時点での配列状態への参照を使用します。 この配列がイテレータの有効期間中に変更されることは決してないため、干渉は不可能であり、イテレータはConcurrentModificationExceptionをスローしないことが保証されます。 イテレータは、イテレータの作成以降のリストへの追加、削除、または変更を反映しません。 イテレータ自体に対する要素変更操作(remove、setおよびadd)はサポートされません。 これらのメソッドは、UnsupportedOperationExceptionをスローします。 
 
nullを含むすべての要素が許可されます。
 
メモリー整合性効果: ほかの並行処理コレクションと同様、オブジェクトをCopyOnWriteArrayListに配置する前のスレッド内のアクションは、別のスレッドでのその要素へのアクセスまたはCopyOnWriteArrayListからの削除に続くアクションよりも前に発生します。
 
このクラスは、Java Collections Frameworkのメンバーです。
| コンストラクタ | 説明 | 
|---|---|
| CopyOnWriteArrayList() | 空のリストを作成します。 | 
| CopyOnWriteArrayList(Collection<? extends E> c) | 指定されたコレクションの要素が含まれているリストを、要素がコレクションのイテレータによって返される順序で作成します。 | 
| CopyOnWriteArrayList(E[] toCopyIn) | 指定された配列のコピーを保持するリストを作成します。 | 
| 修飾子と型 | メソッド | 説明 | 
|---|---|---|
| boolean | add(E e) | このリストの最後に、指定された要素を追加します。 | 
| void | add(int index, E element) | このリスト内の指定された位置に指定された要素を挿入します。 | 
| boolean | addAll(Collection<? extends E> c) | 指定されたコレクション内のすべての要素を、指定されたコレクションのイテレータによって返される順序でこのリストの最後に追加します。 | 
| boolean | addAll(int index, Collection<? extends E> c) | 指定されたコレクション内のすべての要素を、このリストの指定された位置に挿入します。 | 
| int | addAllAbsent(Collection<? extends E> c) | このリストに含まれていない、指定されたコレクション内のすべての要素を、指定されたコレクションのイテレータによって返される順序でこのリストの最後に追加します。 | 
| boolean | addIfAbsent(E e) | 要素が存在しない場合、要素を追加します。 | 
| void | clear() | このリストからすべての要素を削除します。 | 
| Object | clone() | このリストのシャロー・コピーを返します。 | 
| boolean | contains(Object o) | 指定の要素がこのリストに含まれている場合に trueを返します。 | 
| boolean | containsAll(Collection<?> c) | 指定されたコレクションのすべての要素がこのリストに含まれている場合に trueを返します。 | 
| boolean | equals(Object o) | 指定されたオブジェクトがこのリストと等しいかどうかを比較します。 | 
| void | forEach(Consumer<? super E> action) | Iterableの各要素に対して指定されたアクションを、すべての要素が処理されるか、アクションが例外をスローするまで実行します。 | 
| E | get(int index) | このリスト内の指定された位置にある要素を返します。 | 
| int | hashCode() | このリストのハッシュ・コード値を返します。 | 
| int | indexOf(E e, int index) | 指定された要素をリスト内で indexから検索して最初に検出された位置のインデックスを返します。要素が見つからない場合は -1を返します。 | 
| int | indexOf(Object o) | 指定された要素がこのリスト内で最初に検出された位置のインデックスを返します。指定された要素がこのリストにない場合は -1を返します。 | 
| boolean | isEmpty() | このリストに要素がない場合に trueを返します。 | 
| Iterator<E> | iterator() | このリスト内の要素を適切な順序で反復するイテレータを返します。 | 
| int | lastIndexOf(E e, int index) | 指定された要素をリスト内で indexから後向きに検索して最後に検出された位置のインデックスを返します。要素が見つからない場合は -1を返します。 | 
| int | lastIndexOf(Object o) | 指定された要素がこのリスト内で最後に検出された位置のインデックスを返します。指定された要素がこのリストにない場合は -1を返します。 | 
| ListIterator<E> | listIterator() | このリスト内の要素を適切な順序で反復するリスト・イテレータを返します。 | 
| ListIterator<E> | listIterator(int index) | リスト内の指定された位置で始まる、リスト内の要素を適切な順序で反復するリスト・イテレータを返します。 | 
| E | remove(int index) | このリストの指定された位置にある要素を削除します。 | 
| boolean | remove(Object o) | 指定された要素がこのリストにあれば、その最初のものをリストから削除します。 | 
| boolean | removeAll(Collection<?> c) | リストから、指定されたコレクション内に保持されているすべての要素を削除します。 | 
| boolean | removeIf(Predicate<? super E> filter) | 指定された述語を満たすこのコレクションの要素をすべて削除します。 | 
| void | replaceAll(UnaryOperator<E> operator) | このリストの各要素を、その要素に演算子を適用した結果で置換します。 | 
| boolean | retainAll(Collection<?> c) | 指定されたコレクション内に保持されている、リスト内の要素だけを保持します。 | 
| E | set(int index, E element) | このリストの指定された位置にある要素を、指定された要素で置き換えます。 | 
| int | size() | このリスト内にある要素の数を返します。 | 
| void | sort(Comparator<? super E> c) | 指定された Comparatorが示す順序に従って、このリストをソートします。 | 
| Spliterator<E> | spliterator() | このリスト内の要素に対する Spliteratorを返します。 | 
| List<E> | subList(int fromIndex, int toIndex) | このリストの、 fromIndex(これを含む)とtoIndex(これを含まない)の間の部分のビューを返します。 | 
| Object[] | toArray() | このリスト内のすべての要素を適切な順序で(最初の要素から最後の要素へ)含んでいる配列を返します。 | 
| <T> T[] | toArray(T[] a) | このリスト内のすべての要素を適切な順序で(最初の要素から最後の要素へ)含んでいる配列を返します。返される配列の実行時の型は、指定された配列の型になります。 | 
| String | toString() | このリストの文字列表現を返します。 | 
parallelStream, streampublic CopyOnWriteArrayList()
public CopyOnWriteArrayList(Collection<? extends E> c)
c - 最初に保持されていた要素のコレクションNullPointerException - 指定されたコレクションがnullである場合public CopyOnWriteArrayList(E[] toCopyIn)
toCopyIn - 配列(この配列のコピーが内部配列として使用される)NullPointerException - 指定された配列がnullである場合public int size()
public boolean isEmpty()
trueを返します。public boolean contains(Object o)
trueを返します。 つまり、このリストに、(o==null ? e==null : o.equals(e))となる要素eが1つ以上含まれている場合にのみtrueを返します。 public int indexOf(Object o)
public int indexOf(E e, int index)
indexから検索して最初に検出された位置のインデックスを返します。要素が見つからない場合は -1を返します。 つまり、(i >= index && (e==null ? get(i)==null : e.equals(get(i))))となる最小のインデックスiか、またはこのようなインデックスが存在しない場合は-1を返します。 e - 検索する要素index - 検索開始位置のインデックスindex以降の位置で、要素がリスト内で最初に現れる位置のインデックス。要素が見つからない場合は-1。IndexOutOfBoundsException - 指定されたインデックスが負の値の場合public int lastIndexOf(Object o)
lastIndexOf、インタフェースList<E>o - 検索する要素public int lastIndexOf(E e, int index)
indexから後向きに検索して最後に検出された位置のインデックスを返します。要素が見つからない場合は -1を返します。 つまり、(i <= index && (e==null ? get(i)==null : e.equals(get(i))))となる最大のインデックスiか、またはこのようなインデックスが存在しない場合は-1を返します。 e - 検索する要素index - 逆方向の検索開始位置のインデックスindex以前の位置で、要素がリスト内で最後に現れる位置のインデックス。要素が見つからない場合は -1。IndexOutOfBoundsException - 指定されたインデックスが、このリストの現在のサイズに等しいかそれよりも大きい場合public Object clone()
public Object[] toArray()
返される配列は、それへの参照がこのリストで保持されない場合に、安全になります。 (つまり、このメソッドは新しい配列を割り当てます)。 このため、呼出し側は、返された配列を自由に変更できます。
このメソッドは、配列ベースのAPIとコレクションベースのAPIの間の橋渡し役として機能します。
toArray、インタフェースCollection<E>toArray、インタフェースList<E>Arrays.asList(Object[])public <T> T[] toArray(T[] a)
リストが指定された配列に収まり、その配列にさらに余裕がある場合(つまり、配列がリストより多くの要素を持つ場合)、その配列内でリストの終端よりあとの要素はnullに設定されます。 (これは、呼出し側がこのリストにnull要素が1つも含まれていないことがわかっている場合にのみ、このリストの長さを判定するのに役立ちます。) 
 
toArray()メソッドと同じように、このメソッドは、配列ベースのAPIとコレクションベースのAPIの間の橋渡し役として機能します。 さらに、このメソッドでは出力配列の実行時の型を正確に制御できるため、環境によっては割当ての手間を抑えるために使用できます。 
 
xが、文字列だけからなるリストであることがわかっていると仮定します。 次のコードを使うと、新しく割り当てられたStringの配列内にリストをダンプできます。 
  
  String[] y = x.toArray(new String[0]);
 toArray(new Object[0])は、機能の点でtoArray()と同一です。toArray、インタフェースCollection<E>toArray、インタフェースList<E>T - コレクションを含む配列の実行時の型a - 配列が十分な大きさを持つ場合は、このリストの要素の格納先の配列。配列のサイズが十分でない場合は、同じ実行時の型で新しい配列が格納用として割り当てられる。ArrayStoreException - 指定された配列の実行時の型が、このリスト内のすべての要素の実行時の型のスーパー・タイプではない場合NullPointerException - 指定された配列がnullである場合public E get(int index)
get、インタフェースList<E>index - 返される要素のインデックスIndexOutOfBoundsException - インデックスが範囲外の場合(index < 0||index>= size())public E set(int index, E element)
set、インタフェースList<E>index - 置換される要素のインデックスelement - 指定された位置に格納される要素IndexOutOfBoundsException - インデックスが範囲外の場合(index < 0||index>= size())public boolean add(E e)
add、インタフェースCollection<E>add、インタフェースList<E>e - リストに追加される要素true (Collection.add(E)で指定されているとおり)public void add(int index,
                E element)
add、インタフェースList<E>index - 指定の要素が挿入される位置のインデックスelement - 挿入される要素IndexOutOfBoundsException - インデックスが範囲外の場合(index < 0||index> size())public E remove(int index)
remove、インタフェースList<E>index - 削除される要素のインデックスIndexOutOfBoundsException - インデックスが範囲外の場合(index < 0||index>= size())public boolean remove(Object o)
(o==null ? get(i)==null : o.equals(get(i)))となる、最小のインデックス値iを持つ要素を削除します(そのような要素が存在する場合)。 指定された要素がこのリストに含まれていた場合(すなわち、呼出しの結果としてこのリストが変更された場合)はtrueを返します。 public boolean addIfAbsent(E e)
e - このリストに追加される要素(要素が存在しない場合)truepublic boolean containsAll(Collection<?> c)
trueを返します。containsAll、インタフェースCollection<E>containsAll、インタフェースList<E>c - このリストにあるかどうかがチェックされるコレクションtrueNullPointerException - 指定されたコレクションがnullである場合contains(Object)public boolean removeAll(Collection<?> c)
removeAll、インタフェースCollection<E>removeAll、インタフェースList<E>c - このリストから削除される要素を含むコレクションtrueClassCastException - このリストのある要素のクラスが、指定されたコレクションと互換でない場合(任意)NullPointerException - このリストにnull要素が含まれており、指定されたコレクションがnull要素を許可しない場合(任意)、または指定されたコレクションがnullの場合remove(Object)public boolean retainAll(Collection<?> c)
retainAll、インタフェースCollection<E>retainAll、インタフェースList<E>c - このリストで保持される要素を含むコレクションtrueClassCastException - このリストのある要素のクラスが、指定されたコレクションと互換でない場合(任意)NullPointerException - このリストにnull要素が含まれており、指定されたコレクションがnull要素を許可しない場合(任意)、または指定されたコレクションがnullの場合remove(Object)public int addAllAbsent(Collection<? extends E> c)
c - このリストに追加される要素を含むコレクションNullPointerException - 指定されたコレクションがnullである場合addIfAbsent(Object)public void clear()
public boolean addAll(Collection<? extends E> c)
addAll、インタフェースCollection<E>addAll、インタフェースList<E>c - このリストに追加される要素を含むコレクションtrueNullPointerException - 指定されたコレクションがnullである場合add(Object)public boolean addAll(int index,
                      Collection<? extends E> c)
addAll、インタフェースList<E>index - 指定されたコレクションの最初の要素を挿入する位置のインデックスc - このリストに追加される要素を含むコレクションtrueIndexOutOfBoundsException - インデックスが範囲外の場合(index < 0||index> size())NullPointerException - 指定されたコレクションがnullである場合add(int,Object)public void forEach(Consumer<? super E> action)
IterableIterableの各要素に対して指定されたアクションを、すべての要素が処理されるか、アクションが例外をスローするまで実行します。 実装クラスで指定されない場合は、反復の順序でアクションが実行されます(反復順序が指定されている場合)。 アクションによってスローされた例外は、呼出し側に中継されます。 public boolean removeIf(Predicate<? super E> filter)
CollectionremoveIf、インタフェースCollection<E>filter - 削除される要素に対してtrueを返す述語truepublic void replaceAll(UnaryOperator<E> operator)
ListreplaceAll、インタフェースList<E>operator - 各要素に適用する演算子public void sort(Comparator<? super E> c)
ListComparatorが示す順序に従って、このリストをソートします。
 このリストの要素はすべて、指定されたコンパレータを使用して相互に比較可能であることが必要です(つまり、リストの要素e1およびe2に対して、c.compare(e1, e2)からClassCastExceptionがスローされないようにする必要があります)。
 
指定されたコンパレータがnullの場合は、リストの全要素でComparableインタフェースを実装し、要素の自然順序を使用する必要があります。
 
このリストは変更可能でなければなりませんが、サイズ変更はできなくてもかまいません。
public String toString()
"[]")で囲んで示すリストです。 隣接する要素は、文字", " (カンマと空白文字)によって区切られます。 要素は、String.valueOf(Object)により文字列に変換されます。 public boolean equals(Object o)
Listでもあり、指定されたリストでiteratorによって返された要素のシーケンスが、このリストでイテレータによって返されたシーケンスと同じである場合はtrueを返します。 この2つのシーケンスは、長さが同じで、シーケンス内の同じ位置にある対応する要素が等しい場合に同じであると見なされます。 (e1==null ? e2==null : e1.equals(e2))の場合、2つの要素e1とe2は等しいと見なされます。 equals、インタフェースCollection<E>equals、インタフェースList<E>equals、クラスObjecto - このリストと等しいかどうかを比較するオブジェクトtrueObject.hashCode()、HashMappublic int hashCode()
この実装は、List.hashCode()内の定義を使用します。
hashCode、インタフェースCollection<E>hashCode、インタフェースList<E>hashCode、クラスObjectObject.equals(java.lang.Object), System.identityHashCode(java.lang.Object)public Iterator<E> iterator()
返されるイテレータは、イテレータの構築時のリスト状態のスナップショットを提供します。 イテレータのトラバーサル中に同期化は必要ありません。 イテレータは、removeメソッドをサポートしません。 
public ListIterator<E> listIterator()
返されるイテレータは、イテレータの構築時のリスト状態のスナップショットを提供します。 イテレータのトラバーサル中に同期化は必要ありません。 イテレータは、remove、set、またはaddメソッドをサポートしません。 
listIterator、インタフェースList<E>public ListIterator<E> listIterator(int index)
nextの最初の呼出しによって返される最初の要素を示します。 previousの最初の呼出しは、指定されたインデックスから1を引いたインデックスを持つ要素を返します。 
 返されるイテレータは、イテレータの構築時のリスト状態のスナップショットを提供します。 イテレータのトラバーサル中に同期化は必要ありません。 イテレータは、remove、set、またはaddメソッドをサポートしません。 
listIterator、インタフェースList<E>index - リスト・イテレータから(next呼出しによって)返される最初の要素のインデックスIndexOutOfBoundsException - インデックスが範囲外の場合(index < 0||index> size())public Spliterator<E> spliterator()
Spliteratorを返します。
 Spliteratorは、Spliterator.IMMUTABLE、Spliterator.ORDERED、Spliterator.SIZEDおよびSpliterator.SUBSIZEDを報告します。
 
スプリッテレータは、スプリッテレータが構築されたときのリスト状態のスナップショットを提供します。 スプリッテレータの操作中に同期化は必要ありません。
spliterator、インタフェースIterable<E>spliterator、インタフェースCollection<E>spliterator、インタフェースList<E>Spliteratorpublic List<E> subList(int fromIndex, int toIndex)
fromIndex (これを含む)とtoIndex (これを含まない)の間の部分のビューを返します。 返されるリストはこのリストに連動しているため、返されるリスト内の変更はこのリストに反映されます。 
 バッキング・リスト(つまり、このリスト)が、返されたリストを経由せずに変更された場合、このメソッドで返されたリストのセマンティックスは未定義になります。
subList、インタフェースList<E>fromIndex - subListの下端点(これを含む)toIndex - subListの上端点(これを含まない)IndexOutOfBoundsException - 端点のインデックス値が不正である場合(fromIndex < 0||toIndex> size||fromIndex> toIndex) バグまたは機能を送信 
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。 そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。 
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved.  Use is subject to license terms.  Documentation Redistribution Policyも参照してください。