E
- このセットで保持される要素の型public interface NavigableSet<E> extends SortedSet<E>
SortedSet
です。lower
、floor
、ceiling
、higher
メソッドはそれぞれ、指定された要素よりも小さい要素、小さいか等しい要素、大きいか等しい要素、大きい要素を返します。ただし、そのような要素が存在しない場合はnull
を返します。昇順または降順の順序で、NavigableSet
がアクセスしたり、トラバースしたりできる。descendingSet
メソッドから返されるこのセットのビューでは、関係や方向に関するメソッドがすべて反転されたかのように感じられます。オペレーションやビューのパフォーマンスは通常、降順よりも昇順のほうが高速になります。このインタフェースにはさらに、pollFirst
とpollLast
メソッドも定義されています。これらのメソッドはそれぞれ、最下位の要素、最上位の要素が存在する場合はそれを返して削除し、それ以外の場合はnull
を返します。subSet
、headSet
、およびtailSet
メソッドは、下限と上限を含めるかどうかを記述する追加の引数を受け取るという点で、SortedSet
の類似の名前を持つメソッドとは異なります。どのNavigableSet
のサブセットでもNavigableSet
インタフェースを実装する必要があります。
null
要素を許可する実装では、ナビゲーション・メソッドの戻り値があいまいになる可能性があります。ただし、その場合でも、contains(null)
をチェックすることで、その結果のあいまいさを明確にできます。そのような問題を回避するため、このインタフェースの実装では、null
要素の挿入を許可しないようにすることをお薦めします。(Comparable
要素から成るソート・セットは本来、null
を許可しません。)
subSet(E, E)
、headSet(E)
、およびtailSet(E)
メソッドがSortedSet
を返す仕様になっているのは、既存のSortedSet
実装を互換性を維持しながら改良してNavigableSet
を実装できるようにするためです。ただし、このインタフェースの拡張や実装では、これらのメソッドをオーバーライドしてNavigableSet
が返されるようにすることをお薦めします。
このインタフェースは、Java Collections Frameworkのメンバーです。
修飾子と型 | メソッドと説明 |
---|---|
E |
ceiling(E e)
このセット内で、指定された要素と等しいかそれよりも大きい要素の中で最小のものを返します。そのような要素が存在しない場合は
null を返します。 |
Iterator<E> |
descendingIterator()
このセットの要素のイテレータを降順で返します。
|
NavigableSet<E> |
descendingSet()
このセットに含まれる要素の逆順のビューを返します。
|
E |
floor(E e)
このセット内で、指定された要素と等しいかそれよりも小さい要素の中で最大のものを返します。そのような要素が存在しない場合は
null を返します。 |
SortedSet<E> |
headSet(E toElement)
このセットのtoElementよりも確実に小さい要素を持つ部分のビューを返します。
|
NavigableSet<E> |
headSet(E toElement, boolean inclusive)
このセットの
toElement よりも小さい要素(inclusive がtrueの場合はそれよりも小さいかそれと等しい要素)を含む部分のビューを返します。 |
E |
higher(E e)
このセット内で、指定された要素よりも確実に大きい要素の中で最小のものを返します。そのような要素が存在しない場合は
null を返します。 |
Iterator<E> |
iterator()
このセットの要素のイテレータを昇順で返します。
|
E |
lower(E e)
このセット内で、指定された要素よりも確実に小さい要素の中で最大のものを返します。そのような要素が存在しない場合は
null を返します。 |
E |
pollFirst()
最初(下端)の要素を取得して削除します。このセットが空の場合は
null を返します。 |
E |
pollLast()
最後(上端)の要素を取得して削除します。このセットが空の場合は
null を返します。 |
NavigableSet<E> |
subSet(E fromElement, boolean fromInclusive, E toElement, boolean toInclusive)
このセットの
fromElement - toElement の要素範囲を持つ部分のビューを返します。 |
SortedSet<E> |
subSet(E fromElement, E toElement)
このセットのfromElement (これを含む) - toElement (これを含まない)の要素範囲を持つ部分のビューを返します。
|
SortedSet<E> |
tailSet(E fromElement)
このセットのfromElementに等しいかそれよりも大きい要素を持つ部分のビューを返します。
|
NavigableSet<E> |
tailSet(E fromElement, boolean inclusive)
このセットの
fromElement よりも大きい要素(inclusive がtrueの場合はそれよりも大きいかそれと等しい要素)を含む部分のビューを返します。 |
comparator, first, last, spliterator
add, addAll, clear, contains, containsAll, equals, hashCode, isEmpty, remove, removeAll, retainAll, size, toArray, toArray
parallelStream, removeIf, stream
E lower(E e)
null
を返します。e
- 照合する値e
よりも小さい要素の中で最大のもの。そのような要素が存在しない場合はnull
ClassCastException
- 指定された要素を、セット内に現在存在している要素と比較できない場合NullPointerException
- 指定された要素がnullであり、このセットがnull要素を許可しない場合E floor(E e)
null
を返します。e
- 照合する値e
と等しいか、それよりも小さい要素の中で最大のもの。そのような要素が存在しない場合はnull
ClassCastException
- 指定された要素を、セット内に現在存在している要素と比較できない場合NullPointerException
- 指定された要素がnullであり、このセットがnull要素を許可しない場合E ceiling(E e)
null
を返します。e
- 照合する値e
と等しいか、それよりも大きい要素の中で最小のもの。そのような要素が存在しない場合はnull
ClassCastException
- 指定された要素を、セット内に現在存在している要素と比較できない場合NullPointerException
- 指定された要素がnullであり、このセットがnull要素を許可しない場合E higher(E e)
null
を返します。e
- 照合する値e
よりも大きい要素の中で最小のもの。そのような要素が存在しない場合はnull
ClassCastException
- 指定された要素を、セット内に現在存在している要素と比較できない場合NullPointerException
- 指定された要素がnullであり、このセットがnull要素を許可しない場合E pollFirst()
null
を返します。null
E pollLast()
null
を返します。null
NavigableSet<E> descendingSet()
remove
オペレーションを除く)。
返されるセットの順序付けは、Collections.reverseOrder
(comparator())と同等になります。式s.descendingSet().descendingSet()
から返されるs
のビューは基本的にs
と同等になります。
Iterator<E> descendingIterator()
descendingSet().iterator()
と同等です。NavigableSet<E> subSet(E fromElement, boolean fromInclusive, E toElement, boolean toInclusive)
fromElement
- toElement
の要素範囲を持つ部分のビューを返します。fromElement
とtoElement
が等しい場合、返されるセットは、fromInclusive
とtoInclusive
の両方がtrueでないかぎり、空になります。返されるセットはこのセットに連動しており、返されるセットでの変更はこのセットに反映され、その逆の場合も同様です。返されるセットは、このセットがサポートする任意のセット・オペレーションをすべてサポートします。
返されるセットは、その範囲外の要素が挿入されようとすると、IllegalArgumentException
をスローします。
fromElement
- 返されるセットの下端点fromInclusive
- 返されるビューに下端点が含まれる場合はtrue
toElement
- 返されるセットの上端点toInclusive
- 返されるビューに上端点が含まれる場合はtrue
fromElement
(これを含む) - toElement
(これを含まない)の要素範囲を持つ部分のビューClassCastException
- このセットのコンパレータを使用して(このセットがコンパレータを持たない場合は自然順序付けを使用して)、fromElement
とtoElement
を相互に比較できない場合。実装は、セット内に現在存在している要素とfromElement
またはtoElement
とを比較できない場合にこの例外をスローできる。ただし、必須ではない。NullPointerException
- fromElement
またはtoElement
がnullであり、このセットがnull要素を許可しない場合IllegalArgumentException
- fromElement
がtoElement
よりも大きい場合、またはこのセット自体が制限された範囲を持っており、fromElement
またはtoElement
がその範囲から外れている場合NavigableSet<E> headSet(E toElement, boolean inclusive)
toElement
よりも小さい要素(inclusive
がtrueの場合はそれよりも小さいかそれと等しい要素)を含む部分のビューを返します。返されるセットはこのセットに連動しており、返されるセットでの変更はこのセットに反映され、その逆の場合も同様です。返されるセットは、このセットがサポートする任意のセット・オペレーションをすべてサポートします。
返されるセットは、その範囲外の要素が挿入されようとすると、IllegalArgumentException
をスローします。
toElement
- 返されるセットの上端点inclusive
- 返されるビューに上端点が含まれる場合はtrue
toElement
よりも小さい要素(inclusive
がtrueの場合はそれよりも小さいかそれと等しい要素)を含む部分のビューClassCastException
- toElement
がこのセットのコンパレータと互換性がない場合(または、そのセットがコンパレータを持たない場合、toElement
がComparable
を実装していない場合)。実装は、セット内に現在存在している要素とtoElement
とを比較できない場合にこの例外をスローできる。ただし、必須ではない。NullPointerException
- toElement
がnullであり、このセットがnull要素を許可しない場合IllegalArgumentException
- このセット自体が制限された範囲を持っており、toElement
がその範囲から外れている場合NavigableSet<E> tailSet(E fromElement, boolean inclusive)
fromElement
よりも大きい要素(inclusive
がtrueの場合はそれよりも大きいかそれと等しい要素)を含む部分のビューを返します。返されるセットはこのセットに連動しており、返されるセットでの変更はこのセットに反映され、その逆の場合も同様です。返されるセットは、このセットがサポートする任意のセット・オペレーションをすべてサポートします。
返されるセットは、その範囲外の要素が挿入されようとすると、IllegalArgumentException
をスローします。
fromElement
- 返されるセットの下端点inclusive
- 返されるビューに下端点が含まれる場合はtrue
fromElement
に等しいかそれよりも大きい要素を持つ部分のビューClassCastException
- fromElement
がこのセットのコンパレータと互換性がない場合(または、そのセットがコンパレータを持たない場合、fromElement
がComparable
を実装していない場合)。実装は、セット内に現在存在している要素とfromElement
とを比較できない場合にこの例外をスローできる。ただし、必須ではない。NullPointerException
- fromElement
がnullであり、このセットがnull要素を許可しない場合IllegalArgumentException
- このセット自体が制限された範囲を持っており、fromElement
がその範囲から外れている場合SortedSet<E> subSet(E fromElement, E toElement)
返されるセットは、その範囲外の要素が挿入されようとすると、IllegalArgumentExceptionをスローします。
subSet(fromElement, true, toElement, false)
と同等です。
subSet
、インタフェース: SortedSet<E>
fromElement
- 返されるセットの下端点(これを含む)toElement
- 返されるセットの上端点(これを含まない)ClassCastException
- このセットのコンパレータを使用して(このセットがコンパレータを持たない場合は自然順序付けを使用して)、fromElementとtoElementを相互に比較できない場合。実装は、セット内に現在存在している要素とfromElementまたはtoElementとを比較できない場合にこの例外をスローできる。ただし、必須ではない。NullPointerException
- fromElementまたはtoElementがnullであり、このセットがnull要素を許可しない場合IllegalArgumentException
- fromElementがtoElementよりも大きい場合、またはこのセット自体が制限された範囲を持っており、fromElementまたはtoElementがその範囲から外れている場合SortedSet<E> headSet(E toElement)
返されるセットは、その範囲外の要素が挿入されようとすると、IllegalArgumentExceptionをスローします。
headSet(toElement, false)
と同等です。
headSet
、インタフェース: SortedSet<E>
toElement
- 返されるセットの上端点(これを含まない)ClassCastException
- toElementがこのセットのコンパレータと互換性がない場合(または、そのセットがコンパレータを持たない場合、toElementがComparable
を実装していない場合)。実装は、セット内に現在存在している要素とtoElementとを比較できない場合にこの例外をスローできる。ただし、必須ではない。NullPointerException
- toElementがnullであり、このセットがnull要素を許可しない場合IllegalArgumentException
- このセット自体が制限された範囲を持っており、toElementがその範囲から外れている場合SortedSet<E> tailSet(E fromElement)
返されるセットは、その範囲外の要素が挿入されようとすると、IllegalArgumentExceptionをスローします。
tailSet(fromElement, true)
と同等です。
tailSet
、インタフェース: SortedSet<E>
fromElement
- 返されるセットの下端点(これを含む)ClassCastException
- fromElementがこのセットのコンパレータと互換性がない場合(または、そのセットがコンパレータを持たない場合、fromElementがComparable
を実装していない場合)。実装は、セット内に現在存在している要素とfromElementとを比較できない場合にこの例外をスローできる。ただし、必須ではない。NullPointerException
- fromElementがnullであり、このセットがnull要素を許可しない場合IllegalArgumentException
- このセット自体が制限された範囲を持っており、fromElementがその範囲から外れている場合 バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.