Table接口
Table是Guava在jdk的基礎(chǔ)上新增的一種新集合類(lèi)型壮不,是一個(gè)有序的鍵值對(duì)集合汗盘。可能通過(guò)行和列取出對(duì)應(yīng)的值询一。而Table有可能是稀疏的隐孽,不是每個(gè)行列對(duì)都會(huì)有值〗∪铮可以通過(guò)行(列)鍵值或取出一行(列)的數(shù)據(jù)菱阵,也可以同時(shí)使用,取出唯一的映射值缩功。返回集合的方法是返回Tabale的中對(duì)象的引用晴及,修改集合會(huì)修改表,修改表也會(huì)修改集合中的對(duì)象嫡锌。所有函數(shù)操作都是可選的虑稼,如果所選的函數(shù)不可修改Table,則會(huì)拋出UnsupportedOperationException
Table接口的實(shí)現(xiàn)ArrayTable, ForwardingTable, HashBasedTable, ImmutableTable
ArrayTable
ArrayTable的行和列的長(zhǎng)度在初始化后是固定不可變的势木,行與列的鍵值不可為Null蛛倦。Table接口中的clear及remove方法也不可使用,否則會(huì)報(bào)錯(cuò)啦桌,不過(guò)可以用erase及eraseAll方法代替溯壶。ArrayTable比 HashBasedTable和TreeBasedTable更有效地利用內(nèi)存,除非ArrayTable是稀疏的甫男。
注意此實(shí)現(xiàn)并不是線程安全的
ForwardingTable
ForwardingTable是實(shí)現(xiàn)了Table接口的抽象類(lèi)
HashBasedTable
HashBasedTable擁有Tabel接口的所有方法且改,通過(guò)column(c)columnKeySet()和columnMap()返回的視圖是一個(gè)不支持remove()方法的迭代器(Iterator)
此實(shí)現(xiàn)中的所有列和行鍵值,以及對(duì)應(yīng)的值也不可為空查剖。通過(guò)行查詢比通過(guò)列查詢更高效钾虐。因?yàn)樗臄?shù)據(jù)是存儲(chǔ)在Map<R, Map<C, V>>這個(gè)結(jié)構(gòu)中。理論上查詢列的長(zhǎng)度比查詢行的長(zhǎng)度會(huì)消耗更多的時(shí)間笋庄。
注意效扫,此實(shí)現(xiàn)同樣非線程安全。
ImmutableTable
ImmutableTable一經(jīng)初始化直砂,就不可以改變它里面的所有值菌仁,相當(dāng)于只讀。許多其他重要屬性在ImmutableCollection
RowSortedTable接口
RowSortedTable是一個(gè)繼承Table的接口静暂,它的特別之處是表格中的行是有序的
RowSortedTable接口的實(shí)現(xiàn)TreeBasedTable
TreeBasedTable
TreeBasedTable是一個(gè)有序的表格济丘,類(lèi)型List,可以通過(guò)自身的comparator比較大小進(jìn)行排序。當(dāng)你構(gòu)造此對(duì)象時(shí)摹迷,如果不為之先指定Comparator疟赊,則會(huì)使用默認(rèn)的Comparator.
rowKeySet()方法返回一個(gè)SortedSet對(duì)象,rowMap()方法返回一個(gè)SortedMap對(duì)象峡碉,用來(lái)代替Set對(duì)象及Map對(duì)象近哟。