[AIGC]Guava中Table、HashBasedTable和TreeBasedTable的详解

Google的Guava库在Java集合框架中增加了许多新的集合类型,其中包括Table、HashBasedTable以及TreeBasedTable。这些建议设计成可以与JDK集合共存,提供了一些我们认为有广泛用途但JDK未提供的功能。

1. Table

Guava的Table代表了一个包含行、列和相应单元格值的表格结构。行和列都可以是任何类型的对象,并且提供了对数据的多种视图。

主要的操作包括:

  • put(R rowKey, C columnKey, V value):添加一个值到表中
  • get(R rowKey, C columnKey):通过行键和列键获取某一个值
  • contains(R rowKey, C columnKey):判断表中是否存在某个元素
  • row(R rowKey):获取一行中所有的元素
  • column(C columnKey):获取一列中所有的元素

2. HashBasedTable

HashBasedTable类实现了Table接口,使用链接哈希表来存储它的元素。rowKey和columnKey都必须是唯一的,组合它们可以找到特定的值。

HashBasedTable特别适合于行和列都非常稀疏的情况。也就是说,对于大部分可能的列和行的组合,其值会是null。

3. TreeBasedTable

TreeBasedTable类也实现了Table接口,它和HashBasedTable很相似,不同的是它按照行和列的顺序存储值。行和列的键需要实现Comparable接口,或者在创建时提供Comparator。

如果你需要对数据集进行排序操作或者需要快速查找操作,那么TreeBasedTable会是一个更好的选择。在处理具有显著排序特性的数据时,TreeBasedTable的表现更佳。

为了最大化效率,你的数据应该尽可能地集中在几个列上。

总结

Guava的Table提供了一种新的集合类型,使得使用两个键(行和列)来索引值成为可能。而HashBasedTable和TreeBasedTable则是Table的两种不同的实现,分别适应了不同的使用场景。

相关推荐
leeyi3 小时前
Prompt 模板:用变量组装发给 AI 的消息
aigc·agent·ai编程
用户5191495848457 小时前
libcurl Headers API 释放后重利用漏洞:跨请求复用头句柄导致堆内存安全风险
人工智能·aigc
用户5191495848457 小时前
CVE-2025-1094 PostgreSQL SQL注入与WebSocket劫持远程代码执行利用工具
人工智能·aigc
用户5191495848451 天前
OpenSSL PKCS#12 PBMAC1 堆栈缓冲区溢出漏洞 (CVE-2025-11187) 分析与验证
人工智能·aigc
用户5191495848451 天前
HP Sound Research SECOMNService 权限提升漏洞利用工具
人工智能·aigc
Awu12272 天前
⚡从零开发 Agent CLI(二):CLI 框架搭建与子命令路由
人工智能·aigc
Awu12272 天前
⚡从零开发 Agent CLI(三):终端样式改造——从 console.log 到交互式 Ink UI
aigc·ai编程
草帽lufei2 天前
下班后把活交给AI,定时器让它晚上继续干活
aigc·ai编程
阿祖zu2 天前
别再优化 RAG 了,适配 Agent 的 LLM Wiki 知识库理念
前端·后端·aigc
墨风如雪2 天前
AI 火了,人人都想开源,GitHub 没你想的那么复杂
aigc