[Jakarta Commons筆記] Commons Collections
Posted on 2005-08-03 09:07 laogao 閱讀(3339) 評論(1) 編輯 收藏 所屬分類: On JavaCommons Collections,又是一個重量級的東西,為Java標(biāo)準(zhǔn)的Collections API提供了相當(dāng)好的補充。我不知道其他人,就我自己而言,讓我用java.util.Collection及其子類,加上java.util.Collections類提供的操作方法,處理一些簡單的數(shù)據(jù)結(jié)構(gòu)問題還可以,稍微復(fù)雜一點的就覺得有點頭痛,很多細(xì)節(jié)的地方需要我插入這樣那樣的小邏輯,或者感覺它太死板,不夠靈活,再或者確實有點晦澀吧。再說了,如果我只是處理一般的數(shù)據(jù)結(jié)構(gòu)問題,為什么不自己用數(shù)組或者自定義的鏈表來做,再加上Jakarta Commons的Lang提供的ArrayUtils、StringUtils等,已經(jīng)基本夠了,性能可以保證,那么還要這個Collections API干嘛。當(dāng)然,說到這里有些偏激了,Collections當(dāng)然有它存在的道理,能夠把常用的數(shù)據(jù)結(jié)構(gòu)歸納起來,以通用的方式去維護和訪問,這應(yīng)該說是一種進步,但是用起來似乎不夠友好。這個時候我就會想,如果Java比現(xiàn)在做得更好用些,或者有一套第三方的API把我的這些需求抽象出來,實現(xiàn)了,該多好。Commons Collections就是這樣一套API。
在這里可以找到下載鏈接:(binary和src都有)
http://jakarta.apache.org/site/downloads/downloads_commons-collections.cgi
目前Commons Collection發(fā)布的最新版本是3.1。建議下載這個3.1版本,頁面上出現(xiàn)的
我們先來瀏覽一下它的包結(jié)構(gòu)。一共是12個:
org.apache.commons.collections – Commons Collections自定義的一組公用的接口和工具類
org.apache.commons.collections.bag – 實現(xiàn)Bag接口的一組類
org.apache.commons.collections.bidimap – 實現(xiàn)BidiMap系列接口的一組類
org.apache.commons.collections.buffer – 實現(xiàn)Buffer接口的一組類
org.apache.commons.collections.collection – 實現(xiàn)java.util.Collection接口的一組類
org.apache.commons.collections.comparators – 實現(xiàn)java.util.Comparator接口的一組類
org.apache.commons.collections.functors – Commons Collections自定義的一組功能類
org.apache.commons.collections.iterators – 實現(xiàn)java.util.Iterator接口的一組類
org.apache.commons.collections.keyvalue – 實現(xiàn)集合和鍵/值映射相關(guān)的一組類
org.apache.commons.collections.list – 實現(xiàn)java.util.List接口的一組類
org.apache.commons.collections.map – 實現(xiàn)Map系列接口的一組類
org.apache.commons.collections.set – 實現(xiàn)Set系列接口的一組類
用過Java Collections API的朋友大概或多或少會同意我如下的劃分:在Java的Collections API中,不狹義的區(qū)分語法上的接口和類,把它們都看作是類的話,大致我們可以發(fā)現(xiàn)三種主要的類別:
1- 容器類:如Collection、List、Map等,用于存放對象和進行簡單操作的;
2- 操作類:如Collections、Arrays等,用于對容器類的實例進行相對復(fù)雜操作如排序等;
3- 輔助類:如Iterator、Comparator等,用于輔助操作類以及外部調(diào)用代碼實現(xiàn)對容器類的操作,所謂輔助,概括而通俗的來講,就是這些類提供一種算法,你給它一個對象或者一組對象,或者僅僅是按一定的規(guī)則調(diào)用它,它給你一個運算后的答案,幫助你正確處理容器對象。比如Iterator會告訴你容器中下一個對象有沒有、是什么,而Comparator將對象大小/先后次序的算法邏輯獨立出來。
同樣,Jakarta Commons Collections我們細(xì)細(xì)看來,也能夠找出類似的劃分:
1- 作為容器類的補充,我們可以找到Bag、Buffer、BidiMap、OrderedMap等等;
2- 作為操作類的補充,我們可以找到CollectionUtils、IteratorUtils、ListUtils、SetUtils等等;
3- 作為輔助類的補充,我們可以找到MapIterator、Closure、Predicate、Transformer等等;
對于這樣的一個大包,當(dāng)然不可能一個類一個類的講了,找一些常用的和有用的當(dāng)做接下來討論的話題吧。大概列個清單:
Bag
HashBag
BagUtils
Buffer
BlockingBuffer
BoundedFifoBuffer
PriorityBuffer
BufferUtils
MultiMap
BidiMap
CaseInsensitiveMap
LazyMap
MapUtils
TypedCollection
CollectionUtils
ReverseComparator
ComparatorChain
NullComparator
FixedOrderComparator
ComparatorUtils
Predicate
AndPredicate
OrPredicate
AllPredicate
OnePredicate
NonePredicate
PredicateUtils
Transformer
ChainedTransformer
SwitchTransformer
TransformerUtils
Closure
ChainedClosure
IfClosure
WhileClosure
ClosureUtils
LoopingIterator
ArrayListIterator
FilterIterator
UniqueFilterIterator
IteratorUtils
總共9組,在接下來的筆記中我們一起慢慢的看。