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