实用的开源工具库Guava之Table

Table接口

Table是Guava在jdk的基础上新增的一种新集合类型,是一个有序的键值对集合。可能通过行和列取出对应的值。而Table有可能是稀疏的,不是每个行列对都会有值。可以通过行(列)键值或取出一行(列)的数据,也可以同时使用,取出唯一的映射值。返回集合的方法是返回Tabale的中对象的引用,修改集合会修改表,修改表也会修改集合中的对象。所有函数操作都是可选的,如果所选的函数不可修改Table,则会抛出UnsupportedOperationException

Table接口的实现ArrayTable, ForwardingTable, HashBasedTable, ImmutableTable

ArrayTable

ArrayTable的行和列的长度在初始化后是固定不可变的,行与列的键值不可为Null。Table接口中的clear及remove方法也不可使用,否则会报错,不过可以用erase及eraseAll方法代替。ArrayTable比 HashBasedTable和TreeBasedTable更有效地利用内存,除非ArrayTable是稀疏的。

注意此实现并不是线程安全的

ForwardingTable

ForwardingTable是实现了Table接口的抽象类

HashBasedTable

HashBasedTable拥有Tabel接口的所有方法,通过column(c)columnKeySet()和columnMap()返回的视图是一个不支持remove()方法的迭代器(Iterator)

此实现中的所有列和行键值,以及对应的值也不可为空。通过行查询比通过列查询更高效。因为它的数据是存储在Map<R, Map<C, V>>这个结构中。理论上查询列的长度比查询行的长度会消耗更多的时间。

注意,此实现同样非线程安全。

ImmutableTable

ImmutableTable一经初始化,就不可以改变它里面的所有值,相当于只读。许多其他重要属性在ImmutableCollection


RowSortedTable接口

RowSortedTable是一个继承Table的接口,它的特别之处是表格中的行是有序的

RowSortedTable接口的实现TreeBasedTable

TreeBasedTable

TreeBasedTable是一个有序的表格,类型List,可以通过自身的comparator比较大小进行排序。当你构造此对象时,如果不为之先指定Comparator,则会使用默认的Comparator.

rowKeySet()方法返回一个SortedSet对象,rowMap()方法返回一个SortedMap对象,用来代替Set对象及Map对象。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,735评论 18 399
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 5,455评论 0 3
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 9,790评论 0 16
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,567评论 11 349
  • 关注我吧给我一个机会写进你心里 我是影子这里是我们的微风清酒 她不喜欢你你做什么都是多余 文影子 你总是问,为什么...
    微风清酒阅读 3,788评论 0 18

友情链接更多精彩内容