E
- このコレクション内に保持される要素の型public class CopyOnWriteArrayList<E> extends Object implements List<E>, RandomAccess, Cloneable, Serializable
、
setなど)が実装される
ArrayList
のスレッド・セーフな変数です。
通常、これは非常に効率が悪いのですが、トラバーサル操作が変更を数の点で大幅に上回る場合には、代替手段よりも効率が良い場合があります。また、これは、トラバーサルを同期できない場合や、同期することを望まないが、並行スレッド間の干渉を排除する必要がある場合に有用です。「スナップショット」スタイルのイテレータ・メソッドは、イテレータの作成時点での配列状態への参照を使用します。この配列がイテレータの有効期間中に変更されることは決してないため、干渉は不可能であり、イテレータは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, stream
public 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
- このリストに追加される要素(要素が存在しない場合)true
public boolean containsAll(Collection<?> c)
true
を返します。containsAll
、インタフェース: Collection<E>
containsAll
、インタフェース: List<E>
c
- このリストにあるかどうかがチェックされるコレクションtrue
NullPointerException
- 指定されたコレクションがnullである場合contains(Object)
public boolean removeAll(Collection<?> c)
removeAll
、インタフェース: Collection<E>
removeAll
、インタフェース: List<E>
c
- このリストから削除される要素を含むコレクションtrue
ClassCastException
- このリストのある要素のクラスが、指定されたコレクションと互換でない場合(任意)NullPointerException
- このリストにnull要素が含まれており、指定されたコレクションがnull要素を許可しない場合(任意)、または指定されたコレクションがnullの場合remove(Object)
public boolean retainAll(Collection<?> c)
retainAll
、インタフェース: Collection<E>
retainAll
、インタフェース: List<E>
c
- このリストで保持される要素を含むコレクションtrue
ClassCastException
- このリストのある要素のクラスが、指定されたコレクションと互換でない場合(任意)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
- このリストに追加される要素を含むコレクションtrue
NullPointerException
- 指定されたコレクションがnullである場合add(Object)
public boolean addAll(int index, Collection<? extends E> c)
addAll
、インタフェース: List<E>
index
- 指定されたコレクションの最初の要素を挿入する位置のインデックスc
- このリストに追加される要素を含むコレクションtrue
IndexOutOfBoundsException
- インデックスが範囲外の場合(index < 0||index> size())NullPointerException
- 指定されたコレクションがnullである場合add(int,Object)
public void forEach(Consumer<? super E> action)
Iterable
Iterable
の各要素に対して指定されたアクションを、すべての要素が処理されるか、アクションが例外をスローするまで実行します。実装クラスで指定されない場合は、反復の順序でアクションが実行されます(反復順序が指定されている場合)。アクションによってスローされた例外は、呼出し側に中継されます。public boolean removeIf(Predicate<? super E> filter)
Collection
removeIf
、インタフェース: Collection<E>
filter
- 削除される要素に対してtrue
を返す述語true
public void replaceAll(UnaryOperator<E> operator)
List
replaceAll
、インタフェース: List<E>
operator
- 各要素に適用する演算子public void sort(Comparator<? super E> c)
List
Comparator
を使用して要素を比較することにより、このリストをソートします。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
、クラス: Object
o
- このリストと等しいかどうかを比較するオブジェクトtrue
Object.hashCode()
、HashMap
public int hashCode()
この実装は、List.hashCode()
内の定義を使用します。
hashCode
、インタフェース: Collection<E>
hashCode
、インタフェース: List<E>
hashCode
、クラス: Object
Object.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>
Spliterator
public 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, 2014, Oracle and/or its affiliates. All rights reserved.