|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object java.util.AbstractCollection<E> java.util.AbstractList<E> java.util.ArrayList<E>
public class ArrayList<E>
List インタフェースのサイズ変更可能な配列の実装です。リストの任意のオペレーションをすべて実装し、null を含むすべての要素を許容します。このクラスは、List インタフェースを実装するほか、リストを格納するために内部的に使われる配列のサイズを操作するメソッドを提供します(このクラスは、同期化されないことを除いて Vector とほぼ同等)。
size、isEmpty、get、set、iterator、および listIterator の処理は、一定の時間で実行されます。add の処理も、一定の償却時間で実行されます。 つまり、n 個の要素を追加するには O(n) 時間が必要です。ほとんどの場合、ほかのすべての処理も比例的な時間で実行されます。定数の係数は、LinkedList の実装の場合より小さくなります。
各 ArrayList のインスタンスには、「サイズ」があります。それは、リストの要素を格納するために使用する配列のサイズで、常にリストのサイズ以上の大きさになります。ArrayList に要素を追加すると、そのサイズは自動的に拡大します。拡大のポリシーについては、要素を追加すると「一定の償却時間コスト」が伴うこと以外は、詳しくは指定されていません。
アプリケーションでは、ensureCapacity を使って ArrayList のインスタンスのサイズを拡大してから、多くの要素を追加できます。これにより、増加に対する再割り当てが軽減される場合があります。
この実装は同期化されません。複数のスレッドが並行して ArrayList のインスタンスにアクセスし、1 つ以上のスレッドが構造的にリストを変更する場合には、リストを外部的に同期化する必要があります。構造的な変更とは、1 つ以上の要素を追加または削除したり、基になる配列のサイズを明示的に変更したりする処理のことです。 要素の値だけを設定する処理は、構造的な変更ではありません。通常、リストの同期をとるには、リストを自然にカプセル化するオブジェクトで同期をとります。
この種のオブジェクトがない場合には、Collections.synchronizedList
メソッドを使用してリストを「ラップ」する必要があります。これは、リストへの偶発的な非同期アクセスを防ぐために、作成時に行うのが最適です。
List list = Collections.synchronizedList(new ArrayList(...));
このクラスの iterator および listIterator メソッドによって返される反復子は、「フェイルファスト」です。反復子の作成後に、反復子自体の remove または add メソッド以外の方法でリストが構造的に変更されると、反復子は ConcurrentModificationException
をスローします。このように、並行して変更が行われると、反復子は、将来の予測できない時点において予測できない動作が発生する危険を回避するために、ただちにかつ手際よく例外をスローします。
通常、非同期の並行変更がある場合、確かな保証を行うことは不可能なので、反復子のフェイルファストの動作を保証することはできません。フェイルファスト反復子は最善努力原則に基づき、ConcurrentModificationException をスローします。したがって、正確を期すためにこの例外に依存するプログラムを書くことは誤りです。「反復子のフェイルファストの動作はバグを検出するためにのみ使用すべきです」。
このクラスは、Java Collections Framework のメンバーです。
Collection
,
List
,
LinkedList
,
Vector
,
直列化された形式フィールドの概要 |
---|
クラス java.util.AbstractList から継承されたフィールド |
---|
modCount |
コンストラクタの概要 | |
---|---|
ArrayList()
初期容量 10 で空のリストを作成します。 |
|
ArrayList(Collection<? extends E> c)
指定されたコレクションの要素が含まれているリストを、要素がコレクションの反復子によって返される順序で作成します。 |
|
ArrayList(int initialCapacity)
指定された初期サイズで空のリストを作成します。 |
メソッドの概要 | ||
---|---|---|
boolean |
add(E e)
リストの最後に、指定された要素を追加します。 |
|
void |
add(int index,
E element)
リスト内の指定された位置に指定された要素を挿入します。 |
|
boolean |
addAll(Collection<? extends E> c)
指定されたコレクション内のすべての要素を、指定されたコレクションの反復子によって返される順序でリストの最後に追加します。 |
|
boolean |
addAll(int index,
Collection<? extends E> c)
指定されたコレクション内のすべての要素を、リストの指定された位置に挿入します。 |
|
void |
clear()
リストからすべての要素を削除します。 |
|
Object |
clone()
ArrayList のインスタンスのシャローコピーを返します。 |
|
boolean |
contains(Object o)
リストに指定の要素がある場合に true を返します。 |
|
void |
ensureCapacity(int minCapacity)
必要に応じて、この ArrayList のインスタンスのサイズを拡大し、少なくとも最小サイズ引数で指定された数の要素を格納できるようにします。 |
|
E |
get(int index)
リスト内の指定された位置にある要素を返します。 |
|
int |
indexOf(Object o)
指定された要素がリスト内で最初に検出された位置のインデックスを返します。 |
|
boolean |
isEmpty()
リストに要素がない場合に true を返します。 |
|
int |
lastIndexOf(Object o)
指定された要素がリスト内で最後に検出された位置のインデックスを返します。 |
|
E |
remove(int index)
リストの指定された位置にある要素を削除します。 |
|
boolean |
remove(Object o)
指定された要素がこのリストにあれば、その最初のものをリストから削除します。 |
|
protected void |
removeRange(int fromIndex,
int toIndex)
このリストから、fromIndex で始まり、toIndex の直前で終わるインデックスを持つすべての要素を削除します。 |
|
E |
set(int index,
E element)
リストの指定された位置にある要素を、指定された要素で置き換えます。 |
|
int |
size()
リスト内にある要素の数を返します。 |
|
Object[] |
toArray()
リスト内のすべての要素を適切な順序で (最初の要素から最後の要素へ) 格納している配列を返します。 |
|
|
toArray(T[] a)
リスト内のすべての要素を適切な順序で (最初の要素から最後の要素へ) 格納している配列を返します。 |
|
void |
trimToSize()
この ArrayList のインスタンスのサイズをリストの現在のサイズに縮小します。 |
クラス java.util.AbstractList から継承されたメソッド |
---|
equals, hashCode, iterator, listIterator, listIterator, subList |
クラス java.util.AbstractCollection から継承されたメソッド |
---|
containsAll, removeAll, retainAll, toString |
クラス java.lang.Object から継承されたメソッド |
---|
finalize, getClass, notify, notifyAll, wait, wait, wait |
インタフェース java.util.List から継承されたメソッド |
---|
containsAll, equals, hashCode, iterator, listIterator, listIterator, removeAll, retainAll, subList |
コンストラクタの詳細 |
---|
public ArrayList(int initialCapacity)
initialCapacity
- リストの初期容量
IllegalArgumentException
- 指定された初期容量が負の場合public ArrayList()
public ArrayList(Collection<? extends E> c)
c
- 要素がリストに配置されるコレクション
NullPointerException
- 指定されたコレクションが null である場合メソッドの詳細 |
---|
public void trimToSize()
public void ensureCapacity(int minCapacity)
minCapacity
- 目的の最小容量public int size()
Collection<E>
内の size
List<E>
内の size
AbstractCollection<E>
内の size
public boolean isEmpty()
Collection<E>
内の isEmpty
List<E>
内の isEmpty
AbstractCollection<E>
内の isEmpty
public boolean contains(Object o)
Collection<E>
内の contains
List<E>
内の contains
AbstractCollection<E>
内の contains
o
- リストにあるかどうかを調べる要素
public int indexOf(Object o)
List<E>
内の indexOf
AbstractList<E>
内の indexOf
o
- 検索する要素
public int lastIndexOf(Object o)
List<E>
内の lastIndexOf
AbstractList<E>
内の lastIndexOf
o
- 検索する要素
public Object clone()
Object
内の clone
Cloneable
public Object[] toArray()
返される配列への参照をこのリストが維持しないという点で、この配列は安全です。(つまり、このメソッドは新しい配列を割り当てる)。このため、呼び出し側は、返された配列を自由に変更できます。
メソッドは、配列ベースの API とコレクションベースの API の間の橋渡し役として機能します。
Collection<E>
内の toArray
List<E>
内の toArray
AbstractCollection<E>
内の toArray
Arrays.asList(Object[])
public <T> T[] toArray(T[] a)
指定された配列にリストが収まり、その配列にさらに余分な領域がある場合、つまり配列にリストより多くの要素がある場合、配列でコレクションの末尾に続く要素は null に設定されます。(これは、呼び出し側がリストに null 要素が含まれていないことがわかっている場合には、リストの長さを判定するのに利用できる。)
Collection<E>
内の toArray
List<E>
内の toArray
AbstractCollection<E>
内の toArray
a
- 配列が十分な大きさを持つ場合は、リストの要素が格納される配列。そうでない場合は、要素を格納するために同じ実行時の型の新しい配列が割り当てられる
ArrayStoreException
- 指定された配列の実行時の型が、このリスト内のすべての要素の実行時の型のスーパータイプでない場合
NullPointerException
- 指定された配列が null である場合public E get(int index)
List<E>
内の get
AbstractList<E>
内の get
index
- 返される要素のインデックス
IndexOutOfBoundsException
- インデックスが範囲外の場合 (index < 0 || index >= size())public E set(int index, E element)
List<E>
内の set
AbstractList<E>
内の set
index
- 置換される要素のインデックスelement
- 指定された位置に格納される要素
IndexOutOfBoundsException
- インデックスが範囲外の場合 (index < 0 || index >= size())public boolean add(E e)
Collection<E>
内の add
List<E>
内の add
AbstractList<E>
内の add
e
- リストに追加される要素
Collection.add(E)
で指定されているとおり)public void add(int index, E element)
List<E>
内の add
AbstractList<E>
内の add
index
- 指定の要素が挿入される位置のインデックスelement
- 挿入される要素
IndexOutOfBoundsException
- インデックスが範囲外の場合 (index < 0 || index > size())public E remove(int index)
List<E>
内の remove
AbstractList<E>
内の remove
index
- 削除される要素のインデックス
IndexOutOfBoundsException
- インデックスが範囲外の場合 (index < 0 || index >= size())public boolean remove(Object o)
Collection<E>
内の remove
List<E>
内の remove
AbstractCollection<E>
内の remove
o
- リストから削除される要素 (その要素が存在する場合)
public void clear()
Collection<E>
内の clear
List<E>
内の clear
AbstractList<E>
内の clear
public boolean addAll(Collection<? extends E> c)
Collection<E>
内の addAll
List<E>
内の addAll
AbstractCollection<E>
内の addAll
c
- 要素がリストに追加されるコレクション
NullPointerException
- 指定されたコレクションが null である場合AbstractCollection.add(Object)
public boolean addAll(int index, Collection<? extends E> c)
List<E>
内の addAll
AbstractList<E>
内の addAll
index
- 指定されたコレクションの最初の要素を挿入する位置のインデックスc
- 要素がリストに追加されるコレクション
IndexOutOfBoundsException
- インデックスが範囲外の場合 (index < 0 || index > size())
NullPointerException
- 指定されたコレクションが null である場合protected void removeRange(int fromIndex, int toIndex)
AbstractList<E>
内の removeRange
fromIndex
- 削除する最初の要素のインデックスtoIndex
- 削除する最後の要素の直後のインデックス
IndexOutOfBoundsException
- fromIndex または toIndex が範囲外の場合 (fromIndex < 0 || fromIndex >= size() || toIndex > size() || toIndex < fromIndex)
|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。