|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
E
- このセットが保持する要素の型public interface Set<E>
重複要素のないコレクションです。すなわち、セットは、e1.equals(e2)
である e1
と e2
の要素ペアは持たず、null 要素を最大 1 つしか持ちません。その名前が示すように、このインタフェースは、数学で言う集合の抽象化オブジェクトをモデル化します。
Set インタフェースは、Collection インタフェースから継承した規定だけでなく、すべてのコンストラクタの規約、および add、equals、hashCode の各メソッドの規約に追加の規定を適用します。便宜上、ほかの継承メソッドの宣言もここに含まれます。これらの宣言に付随する仕様は Set インタフェースに合わせて調整済みですが、追加規定は含まれていません。
コンストラクタについての追加規定として、すべてのコンストラクタは、重複要素のないセットを作成しなければなりません (上記を参照)。
注:可変オブジェクトがセット要素として使用される場合は、細心の注意が必要です。オブジェクトがセット内の要素であるうちに equals 比較に影響する方式でその値が変更された場合、セットの動作は保証されません。この禁止事項の特例により、セットがそれ自体を要素として持つことは許可されません。
セットの実装には、格納できる要素に制限があるものもあります。たとえば、null 要素を禁止する実装や、null 要素の型に制限がある実装もあります。不適当な要素を追加しようとすると、通常 NullPointerException または ClassCastException のようなチェックされない例外がスローされます。不適当な要素を照会しようとすると、例外がスローされる場合や、ただ false を返す場合もあります。 前の動作を禁止する実装もあれば、後の動作を禁止する実装もあります。もう少し一般的に言うと、セットへの挿入がされない不適当な要素を処理しようとすると、例外がスローされる場合や、処理が有効になる場合があります。このインタフェースに関するそうした例外は、「任意」の仕様としてマークされます。
このインタフェースは、Java Collections Framework のメンバーです。
Collection
,
List
,
SortedSet
,
HashSet
,
TreeSet
,
AbstractSet
,
Collections.singleton(java.lang.Object)
,
Collections.EMPTY_SET
メソッドの概要 | ||
---|---|---|
boolean |
add(E e)
指定された要素がセット内になかった場合、セットに追加します (任意のオペレーション)。 |
|
boolean |
addAll(Collection<? extends E> c)
指定されたコレクションのすべての要素について、その要素がこのセット内にない場合、セットに追加します (任意のオペレーション)。 |
|
void |
clear()
セットからすべての要素を削除します (任意のオペレーション)。 |
|
boolean |
contains(Object o)
セットが、指定された要素を保持している場合に true を返します。 |
|
boolean |
containsAll(Collection<?> c)
指定されたコレクションのすべての要素がセット内にある場合に true を返します。 |
|
boolean |
equals(Object o)
指定されたオブジェクトがセットと同じかどうかを比較します。 |
|
int |
hashCode()
セットのハッシュコード値を返します。 |
|
boolean |
isEmpty()
セットが要素を 1 つも保持していない場合に true を返します。 |
|
Iterator<E> |
iterator()
セット内の各要素についての反復子を返します。 |
|
boolean |
remove(Object o)
指定された要素がセット内にあった場合、セットから削除します (任意のオペレーション)。 |
|
boolean |
removeAll(Collection<?> c)
このセットから、指定されたコレクションに含まれる要素をすべて削除します (任意のオペレーション)。 |
|
boolean |
retainAll(Collection<?> c)
セット内の要素のうち、指定されたコレクション内にある要素だけを保持します (任意のオペレーション)。 |
|
int |
size()
セット内の要素数 (そのカーディナリティ) を返します。 |
|
Object[] |
toArray()
セット内のすべての要素が格納されている配列を返します。 |
|
|
toArray(T[] a)
セット内のすべての要素を格納している配列を返します。 |
メソッドの詳細 |
---|
int size()
Collection<E>
内の size
boolean isEmpty()
Collection<E>
内の isEmpty
boolean contains(Object o)
Collection<E>
内の contains
o
- セットにあるかどうかを調べる要素
ClassCastException
- 指定された要素の型が、このセットと互換でない場合 (省略可能)
NullPointerException
- 指定された要素が null であり、このセットが null 要素を許可しない場合 (省略可能)Iterator<E> iterator()
Collection<E>
内の iterator
Iterable<E>
内の iterator
Object[] toArray()
返される配列への参照をセットが維持しないという点で、この配列は安全です。つまり、このメソッドは、セットが配列に連動している場合でも新しい配列を割り当てます。このため、呼び出し側は、返された配列を自由に変更できます。
メソッドは、配列ベースの API とコレクションベースの API の間の橋渡し役として機能します。
Collection<E>
内の toArray
<T> T[] toArray(T[] a)
セットが指定された配列に収まり、その配列にさらに余裕がある場合 (つまり、配列がセットより多くの要素を持つ場合)、その配列内でセットの終端よりあとの要素は null に設定されます。セットに null 要素がないことを呼び出し側が知っている場合にだけ、この特性を利用してセットの長さを判断できます。
反復子によって要素が返される順序をセットが保証する場合、このメソッドは同じ順序で要素を返さなければいけません。
toArray()
メソッドと同じように、このメソッドは、配列ベースの API とコレクションベースの API の間の橋渡し役として機能します。さらに、このメソッドでは、出力配列の実行時の型を正確に制御できるため、環境によっては割り当ての手間を抑えることができます。
x が、文字列だけからなるセットであることがわかっていると仮定します。次のコードを使うと、新しく割り当てられた String の配列にセットをダンプできます。
String[] y = x.toArray(new String[0]);toArray(new Object[0]) は、機能の点で toArray() と同一です。
Collection<E>
内の toArray
a
- セットの要素の格納先の配列。配列のサイズが十分でない場合は、同じ実行時の型で新しい配列が格納用として割り当てられる
ArrayStoreException
- 指定された配列の実行時の型が、このセット内のすべての要素の実行時の型のスーパータイプでない場合
NullPointerException
- 指定された配列が null である場合boolean add(E e)
この規定は、セットがすべての要素を受け付けなければならないことを意味するわけではありません。つまり、セットでは、null を含む任意の要素の追加を拒否したり、例外をスローすることを任意に指定できます (Collection.add
の仕様を参照)。セットの各実装では、セットが持つことのできる要素についての制約を明記するようにしてください。
Collection<E>
内の add
e
- セットに追加される要素
UnsupportedOperationException
- add オペレーションがこのセットでサポートされない場合
ClassCastException
- 指定された要素のクラスが原因で、このセットにその要素を追加できない場合
NullPointerException
- 指定された要素が null であり、このセットが null 要素を許可しない場合
IllegalArgumentException
- 指定された要素のあるプロパティーが原因で、このセットにその要素を追加できない場合boolean remove(Object o)
Collection<E>
内の remove
o
- セットに存在すれば削除されるオブジェクト
ClassCastException
- 指定された要素の型が、このセットと互換でない場合 (省略可能)
NullPointerException
- 指定された要素が null であり、このセットが null 要素を許可しない場合 (省略可能)
UnsupportedOperationException
- remove オペレーションがこのセットでサポートされない場合boolean containsAll(Collection<?> c)
Collection<E>
内の containsAll
c
- このセットに含まれているかどうかを調べるコレクション
ClassCastException
- 指定されたコレクションの 1 つ以上の要素の型が、このセットと互換でない場合 (省略可能)
NullPointerException
- 指定されたコレクションに 1 つ以上の null 要素が含まれており、このセットが null 要素を許可しない場合 (省略可能)、または指定されたコレクションが null の場合contains(Object)
boolean addAll(Collection<? extends E> c)
Collection<E>
内の addAll
c
- このセットに追加される要素を持つコレクション
UnsupportedOperationException
- addAll オペレーションがこのセットでサポートされない場合
ClassCastException
- 指定されたコレクションのある要素のクラスが原因で、このセットにそのコレクションを追加できない場合
NullPointerException
- 指定されたコレクションに 1 つ以上の null 要素が含まれており、このセットが null 要素を許可しない場合、または指定されたコレクションが null の場合
IllegalArgumentException
- 指定されたコレクションのある要素のある特性が原因で、このセットにそのコレクションを追加できない場合add(Object)
boolean retainAll(Collection<?> c)
Collection<E>
内の retainAll
c
- このセットで保持される要素を含むコレクション
UnsupportedOperationException
- retainAll オペレーションがこのセットでサポートされない場合
ClassCastException
- このセットのある要素のクラスが、指定されたコレクションと互換でない場合 (省略可能)
NullPointerException
- このセットに null 要素が含まれており、指定されたコレクションが null 要素を許可しない場合 (省略可能)、または指定されたコレクションが null の場合remove(Object)
boolean removeAll(Collection<?> c)
Collection<E>
内の removeAll
c
- このセットから削除される要素を含むコレクション
UnsupportedOperationException
- removeAll オペレーションがこのセットでサポートされない場合
ClassCastException
- このセットのある要素のクラスが、指定されたコレクションと互換でない場合 (省略可能)
NullPointerException
- このセットに null 要素が含まれており、指定されたコレクションが null 要素を許可しない場合 (省略可能)、または指定されたコレクションが null の場合remove(Object)
,
contains(Object)
void clear()
Collection<E>
内の clear
UnsupportedOperationException
- clear メソッドがこのセットでサポートされない場合boolean equals(Object o)
Collection<E>
内の equals
Object
内の equals
o
- このセットと等しいかどうかが比較されるオブジェクト
Object.hashCode()
,
Hashtable
int hashCode()
Object.hashCode()
の一般規約で要求されるとおりに、任意の 2 つのセット s1 と s2 について、s1.equals(s2) の場合 s1.hashCode()==s2.hashCode() になります。
Collection<E>
内の hashCode
Object
内の hashCode
Object.equals(Object)
,
equals(Object)
|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。