Java 集合中获取数据的前驱和后继元素

devtools/2024/9/23 16:05:30/

目录

1. NavigableSet 和 NavigableMap

2. ListIterator

3. ConcurrentSkipListSet 和 ConcurrentSkipListMap

4.示列


     使用场景

      使用一致性hash时,如何找到一个hash值对应的临近节点,可以使用集合中获取数据的前驱和后继元素实现。

1. NavigableSet 和 NavigableMap

  • 特性:

    • NavigableSet 和 NavigableMap 接口提供了丰富的方法来获取给定元素的前驱和后继元素。
    • higher(E e) 方法返回比给定元素大的最小元素,如果不存在这样的元素,则返回 null
    • lower(E e) 方法返回比给定元素小的最大元素,如果不存在这样的元素,则返回 null
    • ceiling(E e) 方法返回大于或等于给定元素的最小元素,如果不存在这样的元素,则返回 null
    • floor(E e) 方法返回小于或等于给定元素的最大元素,如果不存在这样的元素,则返回 null
  • 实现类:

    • TreeSet 和 TreeMap 是 NavigableSet 和 NavigableMap 的具体实现,它们都是有序的集合。

2. ListIterator

  • 特性:
    • 实现了 List 接口的集合,如 ArrayList 或 LinkedList,可以使用 ListIterator 迭代器来遍历集合。
    • ListIterator 提供了 next() 和 previous() 方法来分别获取下一个和上一个元素。

3. ConcurrentSkipListSet 和 ConcurrentSkipListMap

  • 特性:
    • 这两个类是线程安全的 NavigableSet 和 NavigableMap 的实现。
    • 它们提供和 TreeSet 以及 TreeMap 相同的前驱和后继方法,适用于并发环境。

4.示列

    1. 使用 NavigableSet(TreeSet 示例)

java">import java.util.NavigableSet;
import java.util.TreeSet;public class NavigableSetExample {public static void main(String[] args) {NavigableSet<Integer> set = new TreeSet<>();set.add(1);set.add(3);set.add(5);set.add(7);// 获取给定元素的后继元素Integer higher = set.higher(5); // 返回7// 获取给定元素的前驱元素Integer lower = set.lower(5); // 返回3System.out.println("Higher than 5: " + higher);System.out.println("Lower than 5: " + lower);}
}
java">import java.util.NavigableSet;
import java.util.TreeSet;public class CeilingExample {public static void main(String[] args) {NavigableSet<Integer> set = new TreeSet<>();set.add(1);set.add(3);set.add(5);set.add(7);// 获取大于等于给定元素的最小元素Integer ceiling = set.ceiling(5); // 返回5System.out.println("Ceiling of 5: " + ceiling);}
}

  在这个例子中,当调用 set.ceiling(5); 时,将返回 5。这是因为 5 已经存在于集合中,所以根据 ceiling(E e) 方法的定义,它将返回大于等于给定元素的最小元素,在这个情况下,是 5 本身。

总结

   在 Java 中,如果需要获取某个数据的下一个或上一个数据,可以使用实现了 NavigableSet 或 NavigableMap 接口的集合,如 TreeSet 和 TreeMap,或者其线程安全的版本 ConcurrentSkipListSet 和 ConcurrentSkipListMap。对于实现了 List 接口的集合,可以通过 ListIterator 来获取前后元素。选择合适的集合取决于数据的类型、集合的排序需求以及是否需要线程安全。


http://www.ppmy.cn/devtools/25013.html

相关文章

C/C++程序设计实验报告综合作业 | 小小计算器

本文整理自博主本科大一《C/C程序设计》专业课的课内实验报告&#xff0c;适合C语言初学者们学习、练习。 编译器&#xff1a;gcc 10.3.0 ---- 注&#xff1a; 1.虽然课程名为C程序设计&#xff0c;但实际上当时校内该课的内容大部分其实都是C语言&#xff0c;C的元素最多可能只…

Windows下搭建Flutter开发环境

IDE:VS code Flutter官网:Flutter: 为所有屏幕创造精彩 - Flutter 中文开发者网站 - Flutter 下载&安装 下载Flutter SDK,如图,建议自行下载安装: SDK还是挺大的,近1G,使用迅雷下载会快不少。 下载完成,解压缩到指定目录即可! 设置Local SDK,按下面步骤操作即…

基于LM Studio + LLaMA3 建立本地化的ChatGPT

4月19日&#xff0c;Facebook母公司Meta重磅推出了Llama3。即便大家现在对于大厂和巨头频繁迭代AI模型的行为已经见怪不怪&#xff0c;Meta的Llama3仍旧显得与众不同&#xff0c;因为这是迄今最强大的开源AI模型。LLaMA模型通常采用了类似于GPT&#xff08;由OpenAI开发&#x…

tableau基础学习——添加标靶图、甘特图、瀑布图

标靶图 添加参考线 添加参考分布 甘特图 创建新的字段 如设置延迟天数****计划交货日期-实际交货日期 为正代表提前交货&#xff0c;负则代表延迟交货 步骤&#xff1a;创建——计算新字段 把延迟天数放在颜色、大小里面就可以 瀑布图 两个表按照地区连接 先做个条形图&…

XYCTF 2024

Web 参考博客&#xff1a;https://www.yuque.com/yunzhiyunweiji/wrgkex/rfpnkn0293l7cp09#ezMake ezhttp Via - HTTP | MDN 代理那里难住了 XFF不给用可以用client-ip ezmd5 让我们上传图片并比较&#xff0c;结合题目名可以猜测应该是比较两个图片的md5值是否相同&…

MySQL怎么看死锁记录

这个结果分成三部分&#xff1a; (1) TRANSACTION&#xff0c;是第一个事务的信息&#xff1b; (2) TRANSACTION&#xff0c;是第二个事务的信息&#xff1b; (3)WE ROLL BACK TRANSACTION (1)&#xff0c;是最终的处理结果&#xff0c;表示回滚了第一个事务。 第一个事务的信…

python 注释符

4、注释 1、单行注释 单行注释用于解释代码中的一行或一小段代码。 在Python中&#xff0c;单行注释以#开头&#xff0c;后面的内容都是注释。 单行注释可以放在代码的任何位置&#xff0c;但通常放在代码行的上方或旁边。 单行注释不会影响代码的执行&#xff0c;Python解…

精酿啤酒:酿造工艺的自动化与智能化发展

随着科技的不断进步&#xff0c;自动化与智能化已成为啤酒酿造工艺的重要发展方向。Fendi Club啤酒紧跟时代潮流&#xff0c;积极推动酿造工艺的自动化与智能化发展&#xff0c;旨在提高生产效率、确保产品品质和满足市场需求。 Fendi Club啤酒引入自动化生产设备。他们采用自动…