1. 程式人生 > >java集合類-總結

java集合類-總結

規模 cti tor 刪除 區別 treeset類 baidu 分配 叠代

集合類存放於java.util包中。

集合類存放的都是對象的引用,而非對象本身,出於表達上的便利,我們稱集合中的對象就是指集合中對象的引用(reference)。 集合類型主要有3種:set(集)、list(列表)和map(映射)。 集合接口分為:Collection和Map,list、set實現了Collection接口 總的說來,Java API中所用的集合類,都是實現了Collection接口,他的一個類繼承結構如下: Collection<--List<--Vector<--Stack Collection<--List<--ArrayList
Collection<--List<--LinkedList Collection<--Set<--HashSet
Collection<--Set<--HashSet<--LinkedHashSet Collection<--Set<--SortedSet<--TreeSet Vector : 基於Array的List,其實就是封裝了Array所不具備的一些功能方便我們使用,它不可能走出Array的限制。性能也就不可能超越Array。所以,在可能 的情況下,我們要多運用Array。另外很重要的一點就是Vector“synchronized”的,這個也是Vector和ArrayList的唯一的區別。ArrayList:同Vector一樣是
一個基於數組實現的,但是不同的是ArrayList不是同步的。所以在性能上要比Vector優越一些,但是當運行到多線程環境中時,可需要自己在管理線程的同 步問題。LinkedList:LinkedList不同於前面兩種List,它不是基於Array的,所以不受Array性能的限制。它每一個節點(Node)都包含兩方面的內容:   1.節點本身的數據(data);   2.下一個節點的信息(nextNode)。 所以當對LinkedList做添加,刪除動作的時候就不用像基於Array的List一樣,必須進行大量的 數據移動。只要更改nextNode的相關信息就可以實現了。這就是LinkedList的優勢。
java.util中共有13個類可用於管理集合對象,它們支持集、列表或映射等集合,以下是這些類的簡單介紹 集: HashSet: 使用HashMap的一個集的實現。雖然集定義成無序,但必須存在某種方法能相當高效地找到一個對象。使用一個HashMap對象實現集的存儲和檢索操作是在固定時間內實現的. TreeSet: 在集中以升序對對象排序的集的實現。這意味著從一個TreeSet對象獲得第一個叠代器將按升序提供對象。TreeSet類使用 了一個TreeMap. 列表: Vector: 實現一個類似數組一樣的表,自動增加容量來容納你所需的元素。使用下標存儲和檢索對象就象在一個標準的數組中一樣 。你也可以用一個叠代器從一個Vector中檢索對象。Vector是唯一的同步容器類??當兩個或多個線程同時訪問時也是性能良好的。 Stack: 這個類從Vector派生而來,並且增加了方法實現棧??一種後進先出的存儲結構。 LinkedList: 實現一個鏈表。由這個類定義的鏈表也可以像棧或隊列一樣被使用。 ArrayList: 實現一個數組,它的規模可變並且能像鏈表一樣被訪問。它提供的功能類似Vector類但不同步。 映射: Hashtable: 實現一個映象,所有的鍵必須非空。為了能高效的工作,定義鍵的類必須實現hashcode()方法和equal()方法。這個類 是前面java實現的一個繼承,並且通常能在實現映象的其他類中更好的使用。 HashMap: 實現一個映象,允許存儲空對象,而且允許鍵是空(由於鍵必須是唯一的,當然只能有一個)。 WeakHashMap: 實現這樣一個映象:通常如果一個鍵對一個對象而言不再被引用,鍵/對象對將被舍棄。這與HashMap形成對照,映象 中的鍵維持鍵/對象對的生命周期,盡管使用映象的程序不再有對鍵的引用,並且因此不能檢索對象。 TreeMap: 實現這樣一個映象,對象是按鍵升序排列的。 Set和List都是由公共接口Collection擴展而來,所以它們都可以使用一個類型為Collection的變量來引用。這就意味著任何列表或集構成的集合都可以用這種方式引用,只有映射類除外(但也不是完全排除在外,因為可以從映射獲得一個列表。)所以說,把一個 列表或集傳遞給方法的標準途徑是使用Collection類型的參數。 Vector 還是ArrayList,哪一個更好,為什麽? 要回答這個問題不能一概而論,有時候使用Vector比較好;有時是ArrayList,有時候這兩個都不是最好的選擇。你別指望能夠獲得 一個簡單肯定答案,因為這要看你用它們幹什麽。下面有4個要考慮的因素: (1)API (2)同步處理 (3)數據增長性 (4)使用模式 下面針對這4個方面進行一一探討

API

編輯 在由Ken Arnold等編著的《Java Programming Language》(Addison-Wesley, June 2000)一書中有這樣的描述,Vector類似於 ArrayList.。所有從API的角度來看這兩個類非常相似。但他們之間也還是有一些主要的區別的。 同步性 Vector是同步的。這個類中的一些方法保證了Vector中的對象是線程安全的。而ArrayList則是異步的,因此ArrayList中的對象並不是線程安全的。因為同步的要求會影響執行的效率,所以如果你不需要線程安全的集合那麽使用ArrayList是一個很好的選擇,這樣可以避免由於同步帶來的不必要的性能開銷。 數據增長 從內部實現機制來講ArrayList和Vector都是使用數組(Array)來控制集合中的對象。當你向這兩種類型中增加元素的時候,如果元素 的數目超出了內部數組目前的長度它們都需要擴展內部數組的長度,Vector缺省情況下自動增長原來一倍的數組長度,ArrayList是原來的50%,所以最後你獲得的這個集合所占的空間總是比你實際需要的要大。所以如果你要在集合中保存大量的數據那麽使用Vector 有一些優勢,因為你可以通過設置集合的初始化大小來避免不必要的資源開銷。

使用模式

編輯 在ArrayList和Vector中,從一個指定的位置(通過索引)查找數據或是在集合的末尾增加、移除一個元素所花費的時間是一樣的,這個時間我們用O(1)表示。但是,如果在集合的其他位置增加或移除元素那麽花費的時間會呈線形增長:O(n-i),其中n代表集合中元素的個數,i代表元素增加或移除元素的索引位置。為什麽會這樣呢?以為在進行上述操作的時候集合中第i和第i個元素之後的所有元素都要執行位移的操作。這一切意味著什麽呢? 這意味著,你只是查找特定位置的元素或只在集合的末端增加、移除元素,那麽使用Vector或ArrayList都可以。如果是其他操作,你最好選擇其他的集合操作類。比如,LinkList集合類在增加或移除集合中任何位置的元素所花費的時間都是一樣的—O(1),但它在 索引一個元素的使用卻比較慢-O(i),其中i是索引的位置.使用ArrayList也很容易,因為你可以簡單的使用索引來代替創建iterator 對象的操作。LinkList也會為每個插入的元素創建對象,所有你要明白它也會帶來額外的開銷。 最後,在《Practical Java》一書中Peter Haggar建議使用一個簡單的數組(Array)來代替Vector或ArrayList。尤其是對於執行效 率要求高的程序更應如此。因為使用數組(Array)避免了同步、額外的方法調用和不必要的重新分配空間的操作。

java集合類-總結