怎樣理解Java 容器,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),蓬溪企業(yè)網(wǎng)站建設(shè),蓬溪品牌網(wǎng)站建設(shè),網(wǎng)站定制,蓬溪網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,蓬溪網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
容器主要包括 Collection 和 Map 兩種,Collection 存儲(chǔ)著對(duì)象的集合,而 Map 存儲(chǔ)著鍵值對(duì)(兩個(gè)對(duì)象)的映射表。
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 類似,但它是線程安全的。
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ì)列。
TreeMap:基于紅黑樹(shù)實(shí)現(xiàn)。
HashMap:基于哈希表實(shí)現(xiàn)。
HashTable:和 HashMap 類似,但它是線程安全的, 這意味著同一時(shí)刻多個(gè)線程可以同時(shí)寫(xiě)入 HashTable 并且不會(huì)導(dǎo)致數(shù)據(jù)不一致。 它是遺留類,不應(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)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。