首页 > Java > java教程 > 正文

如何在Java中使用NavigableMap与NavigableSet

P粉602998670
发布: 2025-09-30 11:01:02
原创
792人浏览过
NavigableMap和NavigableSet是Java中支持有序检索的接口,分别扩展自SortedMap和SortedSet,提供lower、floor、ceiling、higher等方法实现邻近元素查找,常用实现类为TreeMap和TreeSet,适用于时间序列、排行榜、范围查询等需高效查找最近匹配项的场景。

如何在java中使用navigablemap与navigableset

在Java中,NavigableMapNavigableSet 是两个非常实用的接口,它们分别扩展了 SortedMapSortedSet,提供了更丰富的导航功能,比如查找最接近的匹配项、反向遍历等。这些功能在处理有序数据时特别有用。

什么是NavigableMap?

NavigableMap 是一个有序的键值映射接口,支持基于接近度的检索操作。常用的实现类是 TreeMap

常用方法包括:

  • lowerKey(K key):返回小于指定键的最大键
  • floorKey(K key):返回小于或等于指定键的最大键
  • ceilingKey(K key):返回大于或等于指定键的最小键
  • higherKey(K key):返回大于指定键的最小键
  • pollFirstEntry():获取并移除最小的映射项
  • pollLastEntry():获取并移除最大的映射项
  • descendingMap():返回反向顺序的视图
  • subMap(K from, boolean fromInclusive, K to, boolean toInclusive):支持开闭区间的子映射

示例代码:

立即学习Java免费学习笔记(深入)”;

NavigableMap map = new TreeMap(); map.put(10, "A"); map.put(20, "B"); map.put(30, "C"); System.out.println(map.lowerKey(25)); // 输出 20 System.out.println(map.ceilingKey(20)); // 输出 20 System.out.println(map.higherKey(20)); // 输出 30 Map.Entry first = map.pollFirstEntry(); System.out.println(first.getKey()); // 输出 10 NavigableMap reverse = map.descendingMap(); System.out.println(reverse); // {30=C, 20=B}

什么是NavigableSet?

NavigableSet 是一个有序集合接口,支持类似的功能。常用实现类是 TreeSet

主要方法有:

如知AI笔记
如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如知AI笔记 27
查看详情 如知AI笔记
  • lower(E e):返回小于指定元素的最大元素
  • floor(E e):返回小于或等于指定元素的最大元素
  • ceiling(E e):返回大于或等于指定元素的最小元素
  • higher(E e):返回大于指定元素的最小元素
  • pollFirst():获取并移除最小元素
  • pollLast():获取并移除最大元素
  • descendingSet():返回反向顺序的集合视图

示例代码:

立即学习Java免费学习笔记(深入)”;

NavigableSet set = new TreeSet(); set.add("apple"); set.add("banana"); set.add("cherry"); System.out.println(set.lower("banana")); // 输出 apple System.out.println(set.ceiling("berry")); // 输出 cherry System.out.println(set.higher("apple")); // 输出 banana String removed = set.pollFirst(); System.out.println(removed); // 输出 apple NavigableSet reverseSet = set.descendingSet(); System.out.println(reverseSet); // [cherry, banana]

实际应用场景

这些接口适合用于需要快速查找“最近”元素的场景,例如:

  • 时间序列数据中查找最近的时间点
  • 排行榜系统中查找前一名或后一名玩家
  • 范围查询,如查找某个价格区间的商品

使用 subMapsubSet 可以高效地提取区间数据,而不需要遍历整个集合。

基本上就这些。掌握 NavigableMap 和 NavigableSet 的关键在于理解它们提供的“邻近查找”能力,以及如何利用有序性提升查询效率。

以上就是如何在Java中使用NavigableMap与NavigableSet的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号