Java集合之NavigableMap与NavigableSet接口 2022-12-14 09:08 181阅读 0赞 本文接着上篇介绍SortedMap和SortedSet接口,介绍他们的扩展接口NavigableMap与NavigableSet接口, 提供了针对给定搜索目标返回最接近匹配项的导航方法。 SortedMap和SortedSet接口两个接口jdk1.2就已经提供,扩展的NavigableMap与NavigableSet接口jdk1.6才开始支持。 ## 1.NavigableSet接口 ## public interface NavigableSet<E> extends SortedSet<E> \{ 所有已知实现类: ConcurrentSkipListSet, TreeSet NavigableSet扩展了 SortedSet,具有了为给定搜索目标报告最接近匹配项的导航方法。方法 lower、floor、ceiling 和 higher 分别返回小于、小于等于、大于等于、大于给定元素的元素,如果不存在这样的元素,则返回 null。 类似地,方法 lowerKey、floorKey、ceilingKey 和 higherKey 只返回关联的键。所有这些方法是为查找条目而不是遍历条目而设计的。 可以按照键的升序或降序访问和遍历 NavigableMap。descendingMap 方法返回映射的一个视图,该视图表示的所有关系方法和方向方法都是逆向的。升序操作和视图的性能很可能比降序操作和视图的性能要好。subMap、headMap 和 tailMap 方法与名称相似的 SortedMap 方法的不同之处在于:可以接受用于描述是否包括(或不包括)下边界和上边界的附加参数。任何 NavigableMap 的 Submap 必须实现 NavigableMap 接口。 此外,此接口还定义了 firstEntry、pollFirstEntry、lastEntry 和 pollLastEntry 方法,它们返回和/或移除最小和最大的映射关系(如果存在),否则返回 null。 subMap(K, K)、headMap(K) 和 tailMap(K) 方法被指定为返回 SortedMap,以允许现有 SortedMap 实现能相容地改进为实现 NavigableMap,但鼓励此接口的扩展和实现重写这些方法以返回 NavigableMap。类似地,可以重写 SortedMap.keySet() 以返回 NavigableSet。 接口方法: <table> <tbody> <tr> <td colspan="2"> <p><strong>方法摘要</strong></p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#ceiling%28E%29" rel="nofollow">ceiling</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> e) <br> 返回此 set 中大于等于给定元素的最小元素;如果不存在这样的元素,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Iterator.html" rel="nofollow">Iterator</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#descendingIterator%28%29" rel="nofollow">descendingIterator</a>() <br> 以降序返回在此 set 的元素上进行迭代的迭代器。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#descendingSet%28%29" rel="nofollow">descendingSet</a>() <br> 返回此 set 中所包含元素的逆序视图。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#floor%28E%29" rel="nofollow">floor</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> e) <br> 返回此 set 中小于等于给定元素的最大元素;如果不存在这样的元素,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/SortedSet.html" rel="nofollow">SortedSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#headSet%28E%29" rel="nofollow">headSet</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> toElement) <br> 返回此 set 的部分视图,其元素严格小于 toElement。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#headSet%28E,%20boolean%29" rel="nofollow">headSet</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> toElement, boolean inclusive) <br> 返回此 set 的部分视图,其元素小于(或等于,如果 inclusive 为 true)toElement。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#higher%28E%29" rel="nofollow">higher</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> e) <br> 返回此 set 中严格大于给定元素的最小元素;如果不存在这样的元素,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Iterator.html" rel="nofollow">Iterator</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#iterator%28%29" rel="nofollow">iterator</a>() <br> 以升序返回在此 set 的元素上进行迭代的迭代器。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#lower%28E%29" rel="nofollow">lower</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> e) <br> 返回此 set 中严格小于给定元素的最大元素;如果不存在这样的元素,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#pollFirst%28%29" rel="nofollow">pollFirst</a>() <br> 获取并移除第一个(最低)元素;如果此 set 为空,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#pollLast%28%29" rel="nofollow">pollLast</a>() <br> 获取并移除最后一个(最高)元素;如果此 set 为空,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#subSet%28E,%20boolean,%20E,%20boolean%29" rel="nofollow">subSet</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> fromElement, boolean fromInclusive, <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> toElement, boolean toInclusive) <br> 返回此 set 的部分视图,其元素范围从 fromElement 到 toElement。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/SortedSet.html" rel="nofollow">SortedSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#subSet%28E,%20E%29" rel="nofollow">subSet</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> fromElement, <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> toElement) <br> 返回此 set 的部分视图,其元素从 fromElement(包括)到 toElement(不包括)。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/SortedSet.html" rel="nofollow">SortedSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#tailSet%28E%29" rel="nofollow">tailSet</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> fromElement) <br> 返回此 set 的部分视图,其元素大于等于 fromElement。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#tailSet%28E,%20boolean%29" rel="nofollow">tailSet</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">E</a> fromElement, boolean inclusive) <br> 返回此 set 的部分视图,其元素大于(或等于,如果 inclusive 为 true)fromElement。</p> </td> </tr> </tbody> </table> 代码实例: 1. //利用实现了NavigableSet的TreeSet做实验 NavigableSet<String> sortedTreeSet = new TreeSet<String>(); // SortedSet接收TreeSet的实例 // 增加元素 sortedTreeSet.add("aa"); sortedTreeSet.add("bb"); sortedTreeSet.add("cc"); sortedTreeSet.add("dd"); sortedTreeSet.add("ee"); System.out.println(sortedTreeSet.size());//5个元素:5 System.out.println( sortedTreeSet.ceiling("cc"));//大于等于cc的最小值,不存在返回null:cc System.out.println(sortedTreeSet.descendingSet());//返回Set的逆序视图:[ee, dd, cc, bb, aa] System.out.println(sortedTreeSet.floor("cc"));//返回小于等于cc的元素的最大值,不存在返回null:cc System.out.println( sortedTreeSet.headSet("cc"));//返回元素小于cc的元素:[aa,bb] System.out.println( sortedTreeSet.headSet("cc", true));//返回元素小于等于cc的元素视图:[aa,bb,cc] System.out.println(sortedTreeSet.higher("cc"));//返回大于给定元素的最小元素:dd System.out.println( sortedTreeSet.lower("cc"));//返回小于cc的最大元素:bb System.out.println(sortedTreeSet.pollFirst());//移除第一个元素:aa System.out.println(sortedTreeSet.pollLast());//移除最后一个元素:ee System.out.println( sortedTreeSet.subSet("aa",true,"dd",true));//返回部分视图,true表示包括当前元素:[bb,cc,dd] System.out.println( sortedTreeSet.subSet("bb","dd"));//返回部分视图包括前面的,不包括后面的:[bb,cc] System.out.println( sortedTreeSet.tailSet("cc"));//返回元素大于cc的元素视图,包括cc:[cc,dd] System.out.println( sortedTreeSet.tailSet("cc", false));//返回元素大于等于cc的元素视图:[dd] System.out.println( sortedTreeSet.iterator());//返回set上的升序排序的迭代器 System.out.println( sortedTreeSet.descendingIterator());//返回set上的降序排序的迭代器 System.out.println("====================================="); [ee, dd, cc, bb, aa] System.out.println(sortedTreeSet.floor("cc"));//返回小于等于cc的元素的最大值,不存在返回null:cc System.out.println( sortedTreeSet.headSet("cc"));//返回元素小于cc的元素:[aa,bb] System.out.println( sortedTreeSet.headSet("cc", true));//返回元素小于等于cc的元素视图:[aa,bb,cc] System.out.println(sortedTreeSet.higher("cc"));//返回大于给定元素的最小元素:dd System.out.println( sortedTreeSet.lower("cc"));//返回小于cc的最大元素:bb System.out.println(sortedTreeSet.pollFirst());//移除第一个元素:aa System.out.println(sortedTreeSet.pollLast());//移除最后一个元素:ee System.out.println( sortedTreeSet.subSet("aa",true,"dd",true));//返回部分视图,true表示包括当前元素:[bb,cc,dd] System.out.println( sortedTreeSet.subSet("bb","dd"));//返回部分视图包括前面的,不包括后面的:[bb,cc] System.out.println( sortedTreeSet.tailSet("cc"));//返回元素大于cc的元素视图,包括cc:[cc,dd] System.out.println( sortedTreeSet.tailSet("cc", false));//返回元素大于等于cc的元素视图:[dd] System.out.println( sortedTreeSet.iterator());//返回set上的升序排序的迭代器 System.out.println( sortedTreeSet.descendingIterator());//返回set上的降序排序的迭代器 System.out.println("====================================="); 结果: 结果: 5 cc [ee, dd, cc, bb, aa] cc [aa, bb] [aa, bb, cc] dd bb aa ee [bb, cc, dd] [bb, cc] [cc, dd] [dd] java.util.TreeMap$KeyIterator@2a139a55 java.util.TreeMap$NavigableSubMap$DescendingSubMapKeyIterator@15db9742 ===================================== ## 2 NavigableMap接口 ## public interface NavigableMap<K,V> extends SortedMap<K,V> \{ 所有已知实现类: ConcurrentSkipListMap, TreeMap NavigableMap扩展了 SortedMap,具有了针对给定搜索目标返回最接近匹配项的导航方法。方法 lowerEntry、floorEntry、ceilingEntry 和 higherEntry 分别返回与小于、小于等于、大于等于、大于给定键的键关联的 Map.Entry 对象,如果不存在这样的键,则返回 null。类似地,方法 lowerKey、floorKey、ceilingKey 和 higherKey 只返回关联的键。所有这些方法是为查找条目而不是遍历条目而设计的。 可以按照键的升序或降序访问和遍历 NavigableMap。descendingMap 方法返回映射的一个视图,该视图表示的所有关系方法和方向方法都是逆向的。升序操作和视图的性能很可能比降序操作和视图的性能要好。subMap、headMap 和 tailMap 方法与名称相似的 SortedMap 方法的不同之处在于:可以接受用于描述是否包括(或不包括)下边界和上边界的附加参数。任何 NavigableMap 的 Submap 必须实现 NavigableMap 接口。 此接口还定义了 firstEntry、pollFirstEntry、lastEntry 和 pollLastEntry 方法,它们返回和/或移除最小和最大的映射关系(如果存在),否则返回 null。 subMap(K, K)、headMap(K) 和 tailMap(K) 方法被指定为返回 SortedMap,以允许现有 SortedMap 实现能相容地改进为实现 NavigableMap,但鼓励此接口的扩展和实现重写这些方法以返回 NavigableMap。类似地,可以重写 SortedMap.keySet() 以返回 NavigableSet。 接口方法: <table> <tbody> <tr> <td colspan="2"> <p><strong>方法摘要</strong></p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#ceilingEntry%28K%29" rel="nofollow">ceilingEntry</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回一个键-值映射关系,它与大于等于给定键的最小键关联;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#ceilingKey%28K%29" rel="nofollow">ceilingKey</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回大于等于给定键的最小键;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#descendingKeySet%28%29" rel="nofollow">descendingKeySet</a>() <br> 返回此映射中所包含键的逆序 <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a> 视图。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">NavigableMap</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#descendingMap%28%29" rel="nofollow">descendingMap</a>() <br> 返回此映射中所包含映射关系的逆序视图。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#firstEntry%28%29" rel="nofollow">firstEntry</a>() <br> 返回一个与此映射中的最小键关联的键-值映射关系;如果映射为空,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#floorEntry%28K%29" rel="nofollow">floorEntry</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回一个键-值映射关系,它与小于等于给定键的最大键关联;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#floorKey%28K%29" rel="nofollow">floorKey</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回小于等于给定键的最大键;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/SortedMap.html" rel="nofollow">SortedMap</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#headMap%28K%29" rel="nofollow">headMap</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> toKey) <br> 返回此映射的部分视图,其键值严格小于 toKey。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">NavigableMap</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#headMap%28K,%20boolean%29" rel="nofollow">headMap</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> toKey, boolean inclusive) <br> 返回此映射的部分视图,其键小于(或等于,如果 inclusive 为 true)toKey。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#higherEntry%28K%29" rel="nofollow">higherEntry</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回一个键-值映射关系,它与严格大于给定键的最小键关联;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#higherKey%28K%29" rel="nofollow">higherKey</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回严格大于给定键的最小键;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#lastEntry%28%29" rel="nofollow">lastEntry</a>() <br> 返回与此映射中的最大键关联的键-值映射关系;如果映射为空,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#lowerEntry%28K%29" rel="nofollow">lowerEntry</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回一个键-值映射关系,它与严格小于给定键的最大键关联;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#lowerKey%28K%29" rel="nofollow">lowerKey</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> key) <br> 返回严格小于给定键的最大键;如果不存在这样的键,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#navigableKeySet%28%29" rel="nofollow">navigableKeySet</a>() <br> 返回此映射中所包含键的 <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableSet.html" rel="nofollow">NavigableSet</a> 视图。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#pollFirstEntry%28%29" rel="nofollow">pollFirstEntry</a>() <br> 移除并返回与此映射中的最小键关联的键-值映射关系;如果映射为空,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/Map.Entry.html" rel="nofollow">Map.Entry</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#pollLastEntry%28%29" rel="nofollow">pollLastEntry</a>() <br> 移除并返回与此映射中的最大键关联的键-值映射关系;如果映射为空,则返回 null。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">NavigableMap</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#subMap%28K,%20boolean,%20K,%20boolean%29" rel="nofollow">subMap</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> fromKey, boolean fromInclusive, <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> toKey, boolean toInclusive) <br> 返回此映射的部分视图,其键的范围从 fromKey 到 toKey。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/SortedMap.html" rel="nofollow">SortedMap</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#subMap%28K,%20K%29" rel="nofollow">subMap</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> fromKey, <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> toKey) <br> 返回此映射的部分视图,其键值的范围从 fromKey(包括)到 toKey(不包括)。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/SortedMap.html" rel="nofollow">SortedMap</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#tailMap%28K%29" rel="nofollow">tailMap</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> fromKey) <br> 返回此映射的部分视图,其键大于等于 fromKey。</p> </td> </tr> <tr> <td> <p> <a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">NavigableMap</a><<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a>,<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">V</a>></p> </td> <td> <p><a href="https://blog.csdn.net/u010126792/article/details/62236367#tailMap%28K,%20boolean%29" rel="nofollow">tailMap</a>(<a href="http://tool.oschina.net/uploads/apidocs/jdk-zh/java/util/NavigableMap.html" rel="nofollow">K</a> fromKey, boolean inclusive) <br> 返回此映射的部分视图,其键大于(或等于,如果 inclusive 为 true)fromKey。</p> </td> </tr> </tbody> </table> 示例代码: NavigableMap<String, Integer> navigatorTreeMap = new TreeMap<String, Integer>(); // SortedMap接收TreeMap的实例 // 增加元素 navigatorTreeMap.put("aa", 11); navigatorTreeMap.put("bb", 22); navigatorTreeMap.put("cc", 33); navigatorTreeMap.put("dd", 44); navigatorTreeMap.put("ee", 55); navigatorTreeMap.put("ff", 55); navigatorTreeMap.put("gg", 55); System.out.println(navigatorTreeMap.size());// 7个元素:7 System.out.println(navigatorTreeMap.ceilingKey("cc"));// 返回大于等于cc的最小键:cc System.out.println(navigatorTreeMap.ceilingEntry("c"));// 返回一个键-值映射关系,它与大于等于cc的最小键关联:cc=33 System.out.println(navigatorTreeMap.descendingMap());// 返回逆序视图:{gg=55, ff=55, ee=55, dd=44, cc=33, bb=22, aa=11} System.out.println(navigatorTreeMap.firstKey());// 最小键:aa System.out.println(navigatorTreeMap.firstEntry());// 最小键对应的k-v键值对:aa=11 System.out.println(navigatorTreeMap.floorEntry("c"));// 返回一个键-值映射关系,它与小于等于给定键的最大键关联:bb=22 System.out.println(navigatorTreeMap.floorKey("cc"));// 返回小于等于cc的最大键:cc System.out.println(navigatorTreeMap.headMap("bb"));// 返回此映射的部分视图,其键值严格小于bb:{aa=11} System.out.println(navigatorTreeMap.headMap("bb", true));// 同上小于等于(true):{aa=11, bb=22} System.out.println(navigatorTreeMap.higherEntry("c"));// 返回一个键-值映射关系,它与小于等于给定键的最大键关联:cc=33 System.out.println(navigatorTreeMap.higherKey("cc"));// 返回小于等于cc的最大键:dd System.out.println(navigatorTreeMap.lastEntry());// 返回一个键-值映射关系,它与小于等于给定键的最大键关联:gg=55 System.out.println(navigatorTreeMap.lastKey());// 返回小于等于cc的最大键:gg System.out.println(navigatorTreeMap.lowerEntry("c"));// 返回一个键-值映射关系,它与小于等于给定键的最大键关联:bb=22 System.out.println(navigatorTreeMap.lowerKey("cc"));// 返回严格小于cc的最大键:bb System.out.println(navigatorTreeMap.pollFirstEntry());// 移除并返回与此映射中的最小键关联的键-值映射关系:aa=11 System.out.println(navigatorTreeMap.pollLastEntry());// 移除并返回与此映射中的最大键关联的键-值映射关系:gg=55 System.out.println(navigatorTreeMap.navigableKeySet());// 返回此映射中所包含键的 // NavigableSet 视图。:[bb, cc, dd, ee, ff] System.out.println(navigatorTreeMap.subMap("aa", true, "dd", true));// 返回部分视图,true表示包括当前元素键值对:{bb=22, cc=33, dd=44} System.out.println(navigatorTreeMap.subMap("bb", "dd"));// 返回部分视图包括前面的元素,不包括后面的:{bb=22, cc=33} System.out.println(navigatorTreeMap.tailMap("cc"));// 返回元素大于cc的元素映射视图,包括cc://{cc=33, dd=44, ee=55, ff=55} System.out.println(navigatorTreeMap.tailMap("cc", false));// 返回元素大于等于cc的元素映射视图:{dd=44, ee=55, ff=55} System.out.println(navigatorTreeMap.descendingMap());// 返回此映射中所包含映射关系的逆序:{ff=55, ee=55, dd=44, cc=33, bb=22}视图。: System.out.println(navigatorTreeMap.descendingKeySet());// 返回此映射中所包含键的逆序 // NavigableSet视图:[ff, ee, dd, cc, bb] 原理简单说明: 之所以可以去到第一个最后一个元素,或者某个元素的前一个,后一个,是因为集合内部的元素是有序的。 举例TreeSet: public class TreeSet<E> extends AbstractSet<E> implements NavigableSet<E>, Cloneable, java.io.Serializable 实现了NavigableSet接口,NavigableSet又继承了SortedSet接口,SortedSet内部有 Comparator<? super E> comparator(); TreeSet内部用NavigableMap来保存数据,分析代码可以内部其实用的treeMap存储数据,所有添加数据使用的也是treeMap的功能,TreeMap.put(); public V put(K key, V value) { Entry<K,V> t = root; if (t == null) { compare(key, key); // type (and possibly null) check root = new Entry<>(key, value, null); size = 1; modCount++; return null; } int cmp; Entry<K,V> parent; // split comparator and comparable paths Comparator<? super K> cpr = comparator; if (cpr != null) { do { parent = t; cmp = cpr.compare(key, t.key); if (cmp < 0) t = t.left; else if (cmp > 0) t = t.right; else return t.setValue(value); } while (t != null); } else { if (key == null) throw new NullPointerException(); @SuppressWarnings("unchecked") Comparable<? super K> k = (Comparable<? super K>) key; do { parent = t; cmp = k.compareTo(t.key); if (cmp < 0) t = t.left; else if (cmp > 0) t = t.right; else return t.setValue(value); } while (t != null); } Entry<K,V> e = new Entry<>(key, value, parent); if (cmp < 0) parent.left = e; else parent.right = e; fixAfterInsertion(e); size++; modCount++; return null; } 每次插入一个数据都会利用比较函数进行key的比较,重新对数据进行排序,保存的数据是有序的,按序取数据也就不足为奇了。 结束!
相关 Java集合之NavigableMap与NavigableSet接口 本文接着上篇介绍SortedMap和SortedSet接口,介绍他们的扩展接口NavigableMap与NavigableSet接口, 提供了针对给定搜索目标返回最接近匹 一时失言乱红尘/ 2022年12月14日 09:08/ 0 赞/ 182 阅读
相关 Java 集合框架系列九:JDK 1.8 SortedSet 和 NavigableSet 详解 SortedSet 继承关系 ![在这里插入图片描述][2020090818320921.png_pic_center] SortedSet 直接继承了 Set,是 我会带着你远行/ 2022年12月05日 01:37/ 0 赞/ 132 阅读
相关 Java集合之List接口 List接口 JDK 1.6.0 对于父类Collection而言,List接口继承了它的所有方法,也定义了它其特有的一些方法。常用的如下: <table> 落日映苍穹つ/ 2022年11月25日 00:49/ 0 赞/ 136 阅读
相关 Java集合概述之Collection接口 Java集合图解: ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ub 朴灿烈づ我的快乐病毒、/ 2022年11月25日 00:38/ 0 赞/ 171 阅读
相关 Java集合之二Collection接口 Collection 接口是 List、Set 和 Queue 接口的父接口,该接口里定义的方法既可用于操作 Set 集合,也可用于操作 List 和 Queue 集合。 C 快来打我*/ 2022年06月03日 03:42/ 0 赞/ 179 阅读
相关 JAVA之数组与集合 1. 数组和集合的区别 \ 区别1 : \ 数组既可以存储基本数据类型,又可以存储引用数据类型,基本数据类型存储的是值,引用数据类型存 淩亂°似流年/ 2022年05月23日 00:48/ 0 赞/ 152 阅读
相关 Java NavigableMap 接口 Java NavigableMap 接口 Java 集合框架的NavigableMap接口提供了在地图条目之间导航的功能。 它被认为是SortedMap的一种。 实现... 朱雀/ 2022年02月19日 12:00/ 1 赞/ 10945 阅读
相关 Java中的Map【三】NavigableMap接口 所使用的jdk版本为1.8版本,先看一下NavigableMap<K,V>在JDK中Map的UML类图中的位置: ![watermark_type_ZmFuZ3 一时失言乱红尘/ 2021年09月20日 23:14/ 0 赞/ 526 阅读
相关 NavigableMap与NavigableSet Java集合框架(JavaCollections Framework)加入了一个新的NavigableMap和NavigableSet接口——可导航的Map和集合。分别的扩展了 向右看齐/ 2021年06月24日 14:37/ 0 赞/ 414 阅读
相关 Java集合类之Map接口之学生花名册 Java集合类之Map接口之学生花名册 任务描述 把给定的学生花名册数据添加到 Map 集合中。 相关知识 在 Java 的集合体系中,主要包含 Collec 电玩女神/ 2021年06月24日 13:57/ 0 赞/ 429 阅读
还没有评论,来说两句吧...