public abstract class AbstractCollection<E> extends Object implements Collection<E>
変更不可能なコレクションを実装するには、このクラスを拡張して、iteratorメソッドおよびsizeメソッドの実装を提供します。(iteratorメソッドが返すイテレータは、hasNextおよびnextを実装している必要があります。)
変更可能なコレクションを実装するには、上記に加えて、このクラスのaddメソッドをオーバーライドすることと(オーバーライドしなかった場合は、UnsupportedOperationExceptionがスローされる)、iteratorメソッドで返されるイテレータがremoveメソッドを実装している必要があります。
Collectionインタフェースの仕様で推奨されているように、通常は、引数なしのvoidコンストラクタ、および引数にCollectionをとるコンストラクタを提供してください。
実装の詳細については、このクラスの抽象メソッド以外の各メソッドのドキュメントを参照してください。より効率的な実装ができるコレクションの場合は、これらのメソッドをオーバーライドしてもかまいません。
このクラスは、Java Collections Frameworkのメンバーです。
Collection
修飾子 | コンストラクタと説明 |
---|---|
protected |
AbstractCollection()
唯一のコンストラクタです。
|
修飾子と型 | メソッドと説明 |
---|---|
boolean |
add(E e)
指定された要素がこのコレクションに格納されていることを保証します(オプションの操作)。
|
boolean |
addAll(Collection<? extends E> c)
指定されたコレクションのすべての要素をこのコレクションに追加します(オプションの操作)。
|
void |
clear()
このコレクションからすべての要素を削除します(オプションの操作)。
|
boolean |
contains(Object o)
指定された要素がコレクションに含まれている場合にtrueを返します。
|
boolean |
containsAll(Collection<?> c)
指定されたコレクションのすべての要素がこのコレクション内にある場合はtrueを返します。
|
boolean |
isEmpty()
このコレクションに要素がない場合にtrueを返します。
|
abstract Iterator<E> |
iterator()
このコレクション中の要素に関係するイテレータを返します。
|
boolean |
remove(Object o)
指定された要素のインスタンスがこのコレクションにあれば、そのインスタンスをコレクションから1つ削除します(オプションの操作)。
|
boolean |
removeAll(Collection<?> c)
指定されたコレクションにも格納されているこのコレクションのすべての要素を削除します(オプションの操作)。
|
boolean |
retainAll(Collection<?> c)
このコレクションにおいて、指定されたコレクションに格納されている要素だけを保持します(オプションの操作)。
|
abstract int |
size()
このコレクション中の要素の数を返します。
|
Object[] |
toArray()
このコレクションの要素がすべて格納されている配列を返します。
|
<T> T[] |
toArray(T[] a)
このコレクション内のすべての要素を保持する配列を返します。返される配列の実行時の型は、指定された配列の型です。
|
String |
toString()
このコレクションの文字列表現を返します。
|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
equals, hashCode, parallelStream, removeIf, spliterator, stream
protected AbstractCollection()
public abstract int size()
Collection
size
、インタフェース: Collection<E>
public boolean isEmpty()
この実装はsize()== 0を返します。
isEmpty
、インタフェース: Collection<E>
public boolean contains(Object o)
この実装はコレクションの各要素について、指定された要素と等しいかどうかを順に繰返し確認します。
contains
、インタフェース: Collection<E>
o
- このコレクション内にあるかどうかが判定される要素ClassCastException
- 指定された要素の型が、このコレクションと互換でない場合(オプション)NullPointerException
- 指定された要素がnullで、このコレクションがnull要素を許可しない場合(オプション)public Object[] toArray()
返される配列への参照をコレクションが維持しないという点で、この配列は安全です。つまり、このメソッドは、コレクションが配列に連動している場合でも新しい配列を割り当てます。このため、呼出し側は、返された配列を自由に変更できます。
このメソッドは、配列ベースのAPIとコレクションベースのAPIの間の橋渡し役として機能します。
この実装は、インデックス0
で始まり、同じ順序で、配列の連続した要素に格納されている、このコレクションのイテレータによって返されるすべての要素を含む配列を返します。返される配列の長さは、コレクションが反復処理時の並行変更を許可する場合と同様に、このコレクションのサイズが反復処理時に変わる場合でも、イテレータによって返される要素の数と等しくなります。size
メソッドは、最適化のヒントとしてしか呼び出されません。イテレータが異なる数の要素を返す場合でも、正しい結果が返されます。
このメソッドは、次と同等です。
List<E> list = new ArrayList<E>(size());
for (E e : this)
list.add(e);
return list.toArray();
toArray
、インタフェース: Collection<E>
public <T> T[] toArray(T[] a)
このコレクションが指定された配列に収まり、その配列にさらに余裕がある場合(つまり、配列がこのコレクションより多くの要素を持つ場合)、その配列内でコレクションの終端よりあとの要素はnullに設定されます。このコレクションにnull要素がないことを呼出し側が知っている場合にだけ、この特性を利用してコレクションの長さを判断できます。
イテレータによって要素が返される順序をコレクションが保証する場合、このメソッドは同じ順序で要素を返さなければなりません。
Collection.toArray()
メソッドと同じように、このメソッドは、配列ベースのAPIとコレクションベースのAPIの間の橋渡し役として機能します。さらに、このメソッドでは、出力配列の実行時の型を正確に制御できるため、環境によっては割当ての手間を抑えることができます。
xが、文字列だけからなるコレクションであることがわかっていると仮定します。次のコードを使うと、新しく割り当てられたStringの配列内にコレクションをダンプできます。
String[] y = x.toArray(new String[0]);toArray(new Object[0])は、機能の点でtoArray()と同一です。
この実装は、インデックス0
で始まり、同じ順序で、配列の連続した要素に格納されている、このコレクションのイテレータによって返されるすべての要素を含む配列を返します。イテレータによって返される要素数が大きすぎて指定された配列に収まらない場合、このコレクションのサイズが反復処理時に変わる場合でも、コレクションが反復処理時に並行変更を許可している場合と同様に、イテレータによって返される要素数と長さが等しい、新しく割り当てられた配列内の要素が返されます。size
メソッドは、最適化のヒントとしてしか呼び出されません。イテレータが異なる数の要素を返す場合でも、正しい結果が返されます。
このメソッドは、次と同等です。
List<E> list = new ArrayList<E>(size());
for (E e : this)
list.add(e);
return list.toArray(a);
toArray
、インタフェース: Collection<E>
T
- コレクションを含む配列の実行時の型a
- 配列が十分な大きさを持つ場合は、このコレクションの要素の格納先の配列。配列のサイズが十分でない場合は、同じ実行時の型で新しい配列が格納用として割り当てられる。ArrayStoreException
- 指定された配列の実行時の型が、このコレクション内のすべての要素の実行時の型のスーパー・タイプではない場合NullPointerException
- 指定された配列がnullである場合public boolean add(E e)
このオペレーションをサポートするコレクションでは、コレクションに追加できる要素について制限がある場合があります。たとえば、コレクションによっては、null要素の追加が許可されないことや、追加される要素の型を制限することがあります。追加される要素に関して制限がある場合は、そのCollectionクラスのドキュメントに明示すべきでしょう。
その要素がすでにあるという以外の理由で特定の要素の追加を拒否する場合、コレクションはfalseを返すのではなく例外をスローする必要があります。これにより、この呼出しが戻ったあとにコレクションが指定された要素を必ず格納するという不変性を保つことができます。
この実装は、常にUnsupportedOperationExceptionをスローします。
add
、インタフェース: Collection<E>
e
- このコレクションにあるかどうかを調べる要素UnsupportedOperationException
- addオペレーションがこのコレクションでサポートされない場合ClassCastException
- 指定された要素のクラスが原因で、このコレクションにその要素を追加できない場合NullPointerException
- 指定された要素がnullで、このコレクションがnull要素を許可しない場合IllegalArgumentException
- 要素のあるプロパティが原因で、このコレクションに要素を追加できない場合IllegalStateException
- 挿入制限のため、この時点で要素を追加できない場合public boolean remove(Object o)
この実装は、コレクションの内容を次々調べ、指定された要素を探します。要素があれば、イテレータのremoveメソッドを使ってコレクションから要素を削除します。
このコレクションのiteratorメソッドが返すイテレータがremoveメソッドを実装せず、指定されたオブジェクトがこのコレクション内にある場合、この実装はUnsupportedOperationExceptionをスローします。
remove
、インタフェース: Collection<E>
o
- このコレクションから削除される要素(その要素が存在する場合)UnsupportedOperationException
- removeオペレーションがこのコレクションでサポートされない場合ClassCastException
- 指定された要素の型が、このコレクションと互換でない場合(オプション)NullPointerException
- 指定された要素がnullで、このコレクションがnull要素を許可しない場合(オプション)public boolean containsAll(Collection<?> c)
この実装は指定されたコレクションの内容を次々調べ、イテレータによって返された各要素について、このコレクションに含まれるかどうかを順番に確認します。すべての要素がこのコレクションにある場合はtrueを返し、そうでない場合はfalseを返します。
containsAll
、インタフェース: Collection<E>
c
- このコレクションにあるかどうかを調べるコレクションClassCastException
- 指定されたコレクションの1つ以上の要素の型が、このコレクションと互換でない場合(オプション)NullPointerException
- 指定されたコレクションに1つ以上のnull要素が含まれており、このコレクションがnull要素を許可しない場合(オプション)、または指定されたコレクションがnullの場合。contains(Object)
public boolean addAll(Collection<? extends E> c)
この実装は、指定されたコレクションに対して反復を行い、イテレータが返すオブジェクトをこのコレクションに順に追加していく操作を繰り返します。
指定されたコレクションが空でない場合は、addメソッドがオーバーライドされないかぎり、この実装はUnsupportedOperationExceptionをスローします。
addAll
、インタフェース: Collection<E>
c
- このコレクションに追加される要素を含むコレクションUnsupportedOperationException
- addAllオペレーションがこのコレクションでサポートされない場合ClassCastException
- 指定されたコレクションの要素のクラスが原因で、このコレクションにその要素を追加できない場合NullPointerException
- 指定されたコレクション内にnull要素が含まれ、このコレクションがnull要素を許可しない場合。または指定されたコレクションがnullの場合IllegalArgumentException
- 指定されたコレクションの要素のあるプロパティが原因で、このコレクションにその要素を追加できない場合IllegalStateException
- 挿入制限のため、この時点で一部の要素を追加できない場合add(Object)
public boolean removeAll(Collection<?> c)
この実装はこのコレクションの内容を次々調べ、イテレータによって返された各要素について、指定されたコレクションに含まれるかどうかを順番に確認します。そのような要素があれば、イテレータのremoveメソッドを使ってこのコレクションから削除します。
iteratorメソッドで返されたイテレータがremoveメソッドを実装せず、指定されたコレクションに共通する要素が1つでもこのコレクション内にある場合は、この実装はUnsupportedOperationExceptionをスローします。
removeAll
、インタフェース: Collection<E>
c
- このコレクションから削除される要素を含むコレクションUnsupportedOperationException
- removeAllメソッドがこのコレクションでサポートされない場合ClassCastException
- このコレクション内の1つ以上の要素の型が、指定されたコレクションと互換でない場合(オプション)NullPointerException
- このコレクションに1つ以上のnull要素が含まれており、指定されたコレクションがnull要素をサポートしない場合(オプション)、または指定されたコレクションがnullの場合remove(Object)
, contains(Object)
public boolean retainAll(Collection<?> c)
この実装はこのコレクションの内容を次々調べ、イテレータによって返された各要素について、指定されたコレクションに含まれるかどうかを順番に確認します。含まれない要素があれば、イテレータのremoveメソッドを使ってこのコレクションから削除します。
iteratorメソッドで返されたイテレータがremoveメソッドを実装せず、指定されたコレクションに含まれない要素が1つでもこのコレクション内にある場合は、この実装はUnsupportedOperationExceptionをスローします。
retainAll
、インタフェース: Collection<E>
c
- このコレクションで保持される要素を含むコレクションUnsupportedOperationException
- retainAllオペレーションがこのコレクションでサポートされない場合ClassCastException
- このコレクション内の1つ以上の要素の型が、指定されたコレクションと互換でない場合(オプション)NullPointerException
- このコレクションに1つ以上のnull要素が含まれており、指定されたコレクションがnull要素を許可しない場合(オプション)、または指定されたコレクションがnullの場合remove(Object)
, contains(Object)
public void clear()
この実装はコレクションに対して、Iterator.removeオペレーションを使用して各要素を削除する操作を繰り返します。ほとんどの実装では、このメソッドをオーバーライドした方がより効率的です。
このコレクションのiteratorメソッドで返されるイテレータがremoveメソッドを実装せず、このコレクションが空でない場合、この実装はUnsupportedOperationExceptionをスローします。
clear
、インタフェース: Collection<E>
UnsupportedOperationException
- clearオペレーションがこのコレクションでサポートされない場合public String toString()
String.valueOf(Object)
により文字列に変換されます。 バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.