Java的集合類是一種特別有用的工具,它可以用于存儲數量不等的多個對象,并可以實現常用的數據結構,如棧、隊列等。Java集合還可以用于板寸具有映射關系的關聯數組。
成都創新互聯公司專注骨干網絡服務器租用10余年,服務更有保障!服務器租用,成都IDC機房托管 成都服務器租用,成都服務器托管,骨干網絡帶寬,享受低延遲,高速訪問。靈活、實現低成本的共享或公網數據中心高速帶寬的專屬高性能服務器。java集合就像是一個容器,我們可以把多個對象(實際上是對象的引用,習慣上叫對象,)保存到集合容器中。在JDK1.5以前java集合會丟失容器中所有對象的數據類型,JDK1.5以后增加了泛型,java集合可以記住容器中對象的數據類型。
Java集合大致可以分為三個體系:Set List Map.所有的集合類都位于java.util包下面。
Collection接口
Collection接口是List、 Set、和Queue接口的父接口。
Collection所代表的是一種規則,它所包含的元素都必須遵循一條或者多條規則。如有些允許重復而有些則不能重復、有些必須要按照順序插入而有些則是散列,有些支持排序有些不支持排序。
一、List接口
List接口是Collection接口的直接接口。List代表的是有序的Collection,集合中的每個元素都有其對應的索引。List中允許有重復的元素,可以通過索引來訪問指定位置的集合元素。因為List集合默認按元素的添加順序設置元素的索引。
(1)ArrayList、Vector、Stack
ArrayList和Vector作為List的兩個典型實現類,完全支持List的全部功能。
ArrayList和Vector類的底層都是基于數組來儲存集合元素,封裝了一個動態的Object[]數組,是一種順序存儲的線性表。
ArrayList和Vector在用法上幾乎完全相同,只是Vector在JDK1.0時就存在,它的方法名比較冗長、比ArrayList包含的方法多,源碼比ArrayList包含的源碼也多,ArrayList的序列化實現比Vector現在Vector基本上被ArrayList所取代了。
主要區別:ArrayList是線程不安全的,Vector是線程安全的。
如果需要在多線程環境下使用List集合,而且需要保證線程安全,依然可以避免使用Vector,而是考慮將ArrayList包裝成線程安全的集合類。Java提供的Collections工具類,通過該工具類synchronizeList方法即可以把ArrayList包裝成線程安全的ArrayList.
Stack
Vector提供了一個子類,它用于模擬“棧”這種數據結構,棧通常是先進后出的容器。Stack提供了額外的5個方法,使得Vector可以當做棧來使用。出棧pop,入棧push,訪問棧頂元素peek(),判斷棧是否為空empty(),檢測一個元素在堆棧中的位置serch().
(2)LinkedList
LinkedList是一個鏈式存儲的線性變,本質上是一個雙向鏈表,它不僅實現了List接口還實現了Dueue接口(雙端隊列,既具有隊列的特征,也具有棧的特征),所以LinkedList不僅可以做雙向鏈表來使用,還可以當棧和隊列來使用。
LinkedList對元素的插入、刪除元素時速度非常快。
LinkdedList也是非同步的。若要實現同步訪問,可以采取
List list = Collections.synchronizeList(new LinkedList(.....));
(3)異同點對比
(1)ArrayList和LinkedList
1)ArrayList是基于動態數組實現的,LinkedList是基于雙向鏈表實現的。
2)ArrayList比較適用于隨機存取,(可直接通過索引,LinkedList需要通過指針遍歷);LinkedList比較適用于增加刪除操作(對于單條的插入和刪除操作ArrayList比LinkedList速度快,對于插入好人刪除操作,ArrayList需要移動后面的所有元素。)
二、Set接口
Set是一種不允許包含相同元素的Collection。它維持自己的內部排序,隨機訪問沒有任何意義。
(1)HashSet
HashSet是Set接口的典型實現,HashSet按Hash算法來儲存集合中的元素,具有很好的存取和查找功能。
具有以下特點:
1)不保證元素的排列順序,有可能變化;
2)HashSet不是同步的;
3)集合元素可以為空。
(2)TreeSet
TreeSet是SortedSet接口的唯一實現,TreeSet可以確保元素處于排序狀態,TreeSet并不是根據元素的插入順序進行排序的,而是根據實際值進行排序。支持兩種排序方式:自然排序和定制排序。
(3)EnumSet
是為枚舉類設計的集合類,EnumSet不允許加入null元素。如果試圖插入null,會拋出空指針異常。
Set的三個實現類都是現成不安全的。
三、Map接口
Map保存具有映射關系的數據,因此Map集合里保存著兩組值,一組值用來保存Map里的key,一組用來保存Map里的value,key和value可以是任何引用類型的數據。
Map里的key不允許重復,value可以重復。key和value之間存在單向的一對一的關系,通過指定的key,總能找到唯一的、確定的value。
(1)HashMap與HashTable
HashMap與HashTable都是Map的典型實現類,他們之間的關系類似于ArrayList和Vector:HashTable是一個古老的Map實現類,在JDK1.0時就出現了。
主要區別:
1)HashTable是一個線程安全的Map實現,但是HashMap是線程不安全的實現,HashMap的性能要比HashTable高一些,盡量避免使用HashTable,多個線程訪問一個Map對象又要保證線程安全時,可以使用Collections中的方法把HashMap變成線程安全的。
2)HashTable不允許使用null作為key和value,如果試圖把null加入HashTable中,將會引發空指針異常。
(2)TreeMap
TreeMap是Map的子接口SortedMap的的實現類,與TreeSet類似的是TreeMap也是基于紅黑樹對TreeMap中所有的key進行排序,從而保證key-value處于有序狀態,TreeMap也有兩種排序方式:
1)自然排序:TreeMap的所有key必須實現Comparable接口,而且所有key應該是同一類的對象,否則會拋出ClassCastException.
2)定制排序:創建TreeMap時,傳入一個Comparator對象,該對象負責對TreeMap中所有的key進行排序。
由于TreeMap支持內部排序,所以通常要比HashMap和HashTable慢。
四、Queue接口
Queue模擬了隊列這種數據結構,隊列通常是“先進先出”的數據結構,通常不允許隨機訪問隊列中的元素。
Queue常用的實現類:LinkedList和PriorityQueue
(1)LinkedList
LinkedList它不僅實現了List接口還實現了Dueue接口(雙端隊列,既具有隊列的特征,也具有棧的特征),Dueue接口是Queue的子接口。
(2)PriorityQueue
PriorityQueue保存隊列元素的的順序并不是按照加入隊列的順序,而是按照隊列元素大小進行重新排序。所以當調用peek和poll方法來取隊列中的元素的時候,并不是先取出來隊列中最小的元素。從這個意義上來看,PriorityQueue已經違反了隊列的基本規則。PriorityQueue不允許插入null元素。
總結:
線程安全的有Vector Stack HashTable
不允許插入空元素的有HashTable PriorityQueue EnumSet
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創新互聯。
當前文章:Java集合繼承體系詳解-創新互聯
網頁地址:http://m.newbst.com/article0/dpehio.html
成都網站建設公司_創新互聯,為您提供全網營銷推廣、品牌網站設計、靜態網站、標簽優化、網站營銷、網站導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯