Table接口
Table是Guava在jdk的基礎(chǔ)上新增的一種新集合類型,是一個有序的鍵值對集合??赡芡ㄟ^行和列取出對應(yīng)的值。而Table有可能是稀疏的,不是每個行列對都會有值??梢酝ㄟ^行(列)鍵值或取出一行(列)的數(shù)據(jù),也可以同時使用,取出唯一的映射值。返回集合的方法是返回Tabale的中對象的引用,修改集合會修改表,修改表也會修改集合中的對象。所有函數(shù)操作都是可選的,如果所選的函數(shù)不可修改Table,則會拋出UnsupportedOperationException
Table接口的實(shí)現(xiàn)ArrayTable, ForwardingTable, HashBasedTable, ImmutableTable
ArrayTable
ArrayTable的行和列的長度在初始化后是固定不可變的,行與列的鍵值不可為Null。Table接口中的clear及remove方法也不可使用,否則會報錯,不過可以用erase及eraseAll方法代替。ArrayTable比 HashBasedTable和TreeBasedTable更有效地利用內(nèi)存,除非ArrayTable是稀疏的。
注意此實(shí)現(xiàn)并不是線程安全的
ForwardingTable
ForwardingTable是實(shí)現(xiàn)了Table接口的抽象類
HashBasedTable
HashBasedTable擁有Tabel接口的所有方法,通過column(c)columnKeySet()和columnMap()返回的視圖是一個不支持remove()方法的迭代器(Iterator)
此實(shí)現(xiàn)中的所有列和行鍵值,以及對應(yīng)的值也不可為空。通過行查詢比通過列查詢更高效。因?yàn)樗臄?shù)據(jù)是存儲在Map<R, Map<C, V>>這個結(jié)構(gòu)中。理論上查詢列的長度比查詢行的長度會消耗更多的時間。
注意,此實(shí)現(xiàn)同樣非線程安全。
ImmutableTable
ImmutableTable一經(jīng)初始化,就不可以改變它里面的所有值,相當(dāng)于只讀。許多其他重要屬性在ImmutableCollection
RowSortedTable接口
RowSortedTable是一個繼承Table的接口,它的特別之處是表格中的行是有序的
RowSortedTable接口的實(shí)現(xiàn)TreeBasedTable
TreeBasedTable
TreeBasedTable是一個有序的表格,類型List,可以通過自身的comparator比較大小進(jìn)行排序。當(dāng)你構(gòu)造此對象時,如果不為之先指定Comparator,則會使用默認(rèn)的Comparator.
rowKeySet()方法返回一個SortedSet對象,rowMap()方法返回一個SortedMap對象,用來代替Set對象及Map對象。