當(dāng)前位置:首頁(yè) > IT技術(shù) > 編程語(yǔ)言 > 正文

Java Review - 集合框架=Collection+Map
2021-11-16 11:43:39

Java Review - 集合框架=Collection+Map_雙向鏈表


概述

容器,就是可以容納其他Java對(duì)象的對(duì)象。 Java Collections Framework(JCF) 為Java開(kāi)發(fā)者提供了通用的容器。

我們知道 Java容器里只能放對(duì)象,對(duì)于基本類型(int, long, float, double等),需要將其包裝成對(duì)象類型后(Integer, Long, Float, Double等)才能放到容器里。很多時(shí)候拆箱和裝箱能夠自動(dòng)完成。

這雖然會(huì)導(dǎo)致額外的性能和空間開(kāi)銷(xiāo),但簡(jiǎn)化了設(shè)計(jì)和編程。


容器 = Collection + Map

容器主要包括 Collection 和 Map 兩種 ;

  • Collection 存儲(chǔ)著對(duì)象的集合
  • Map 存儲(chǔ)著鍵值對(duì)(兩個(gè)對(duì)象)的映射表

Java Review - 集合框架=Collection+Map_雙向鏈表_02

圖片來(lái)源: https://pierrchen.blogspot.com/2014/03/java-collections-framework-cheat-sheet.html

Collection

Set

TreeSet

基于紅黑樹(shù)實(shí)現(xiàn),支持有序性操作,例如根據(jù)一個(gè)范圍查找元素的操作。

但是查找效率不如 HashSet,HashSet 查找的時(shí)間復(fù)雜度為 O(1),TreeSet 則為 O(logN)。


HashSet

基于哈希表實(shí)現(xiàn),支持快速查找,但不支持有序性操作。并且失去了元素的插入順序信息,也就是說(shuō)使用 Iterator 遍歷 HashSet 得到的結(jié)果是不確定的。


LinkedHashSet

具有 HashSet 的查找效率,且內(nèi)部使用雙向鏈表維護(hù)元素的插入順序

List


ArrayList

基于動(dòng)態(tài)數(shù)組實(shí)現(xiàn),支持隨機(jī)訪問(wèn)。


Vector

和 ArrayList 類似,但它是線程安全的


LinkedList

基于雙向鏈表實(shí)現(xiàn),只能順序訪問(wèn),但是可以快速地在鏈表中間插入和刪除元素。不僅如此,LinkedList 還可以用作棧、隊(duì)列和雙向隊(duì)列。


Queue

LinkedList

可以用它來(lái)實(shí)現(xiàn)雙向隊(duì)列


PriorityQueue

基于堆結(jié)構(gòu)實(shí)現(xiàn),可以用它來(lái)實(shí)現(xiàn)優(yōu)先隊(duì)列。

Java Review - 集合框架=Collection+Map_Collection_03


Map

TreeMap

基于紅黑樹(shù)實(shí)現(xiàn)。


HashMap


HashTable

和 HashMap 類似,但它是線程安全的,這意味著同一時(shí)刻多個(gè)線程可以同時(shí)寫(xiě)入 HashTable 并且不會(huì)導(dǎo)致數(shù)據(jù)不一致。它是遺留類,不應(yīng)該去使用它。現(xiàn)在可以使用 ConcurrentHashMap 來(lái)支持線程安全,并且 ConcurrentHashMap 的效率會(huì)更高,因?yàn)?ConcurrentHashMap 引入了分段鎖


LinkedHashMap

使用雙向鏈表來(lái)維護(hù)元素的順序,順序?yàn)椴迦腠樞蚧蛘咦罱钌偈褂?LRU)順序

Java Review - 集合框架=Collection+Map_雙向鏈表_04

本文摘自 :https://blog.51cto.com/u

開(kāi)通會(huì)員,享受整站包年服務(wù)立即開(kāi)通 >