溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

怎樣理解Java 容器

發(fā)布時(shí)間:2021-11-17 14:02:51 來(lái)源:億速云 閱讀:162 作者:柒染 欄目:軟件技術(shù)

怎樣理解Java 容器,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

容器主要包括 Collection 和 Map 兩種,Collection 存儲(chǔ)著對(duì)象的集合,而 Map 存儲(chǔ)著鍵值對(duì)(兩個(gè)對(duì)象)的映射表。

一、Collection

怎樣理解Java 容器

1. 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ù)元素的插入順序。

2. List

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

  • Vector:和 ArrayList 類(lèi)似,但它是線程安全的。

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

3. Queue

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

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

二、Map

怎樣理解Java 容器

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

  • HashMap:基于哈希表實(shí)現(xiàn)。

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

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

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI