文章目錄
概述
容器,就是可以容納其他Java對(duì)象的對(duì)象。 Java Collections Framework(JCF) 為Java開發(fā)者提供了通用的容器。
我們知道 Java容器里只能放對(duì)象,對(duì)于基本類型(int, long, float, double等),需要將其包裝成對(duì)象類型后(Integer, Long, Float, Double等)才能放到容器里。很多時(shí)候拆箱和裝箱能夠自動(dòng)完成。
這雖然會(huì)導(dǎo)致額外的性能和空間開銷,但簡化了設(shè)計(jì)和編程。
容器 = Collection + Map
容器主要包括 Collection 和 Map 兩種 ;
- Collection 存儲(chǔ)著對(duì)象的集合
- Map 存儲(chǔ)著鍵值對(duì)(兩個(gè)對(duì)象)的映射表
圖片來源: https://pierrchen.blogspot.com/2014/03/java-collections-framework-cheat-sheet.html
CollectionSet
TreeSet
基于紅黑樹實(shí)現(xiàn),支持有序性操作,例如根據(jù)一個(gè)范圍查找元素的操作。
但是查找效率不如 HashSet,HashSet 查找的時(shí)間復(fù)雜度為 O(1),TreeSet 則為 O(logN)。
HashSet
基于哈希表實(shí)現(xiàn),支持快速查找,但不支持有序性操作。并且失去了元素的插入順序信息,也就是說使用 Iterator 遍歷 HashSet 得到的結(jié)果是不確定的。
LinkedHashSet
具有 HashSet 的查找效率,且內(nèi)部使用雙向鏈表維護(hù)元素的插入順序
List
ArrayList
基于動(dòng)態(tài)數(shù)組實(shí)現(xiàn),支持隨機(jī)訪問。
Vector
和 ArrayList 類似,但它是線程安全的
LinkedList
基于雙向鏈表實(shí)現(xiàn),只能順序訪問,但是可以快速地在鏈表中間插入和刪除元素。不僅如此,LinkedList 還可以用作棧、隊(duì)列和雙向隊(duì)列。
Queue
LinkedList
可以用它來實(shí)現(xiàn)雙向隊(duì)列
PriorityQueue
基于堆結(jié)構(gòu)實(shí)現(xiàn),可以用它來實(shí)現(xiàn)優(yōu)先隊(duì)列。
Map
TreeMap
基于紅黑樹實(shí)現(xiàn)。
HashMap
HashTable
和 HashMap 類似,但它是線程安全的,這意味著同一時(shí)刻多個(gè)線程可以同時(shí)寫入 HashTable 并且不會(huì)導(dǎo)致數(shù)據(jù)不一致。它是遺留類,不應(yīng)該去使用它?,F(xiàn)在可以使用 ConcurrentHashMap 來支持線程安全,并且 ConcurrentHashMap 的效率會(huì)更高,因?yàn)?ConcurrentHashMap 引入了分段鎖
LinkedHashMap
使用雙向鏈表來維護(hù)元素的順序,順序?yàn)椴迦腠樞蚧蛘咦罱钌偈褂?LRU)順序
本文摘自 :https://blog.51cto.com/u