java容器详解_详解Java 容器(第①篇)——概览

容器主要包括 Collection 和 Map 兩種,Collection 存儲著對象的集合,而 Map 存儲著鍵值對(兩個對象)的映射表。
# 一、Collection

**1. Set**
- TreeSet:基于紅黑樹實現(xiàn),支持有序性操作,例如根據(jù)一個范圍查找元素的操作。 但是查找效率不如 HashSet,HashSet 查找的時間復雜度為 O(1),TreeSet 則為 O(logN)。
- HashSet:基于哈希表實現(xiàn),支持快速查找,但不支持有序性操作。 并且失去了元素的插入順序信息,也就是說使用 Iterator 遍歷 HashSet 得到的結果是不確定的。
- LinkedHashSet:具有 HashSet 的查找效率,且內部使用雙向鏈表維護元素的插入順序。
**2. List**
- ArrayList:基于動態(tài)數(shù)組實現(xiàn),支持隨機訪問。
- Vector:和 ArrayList 類似,但它是線程安全的。
- LinkedList:基于雙向鏈表實現(xiàn),只能順序訪問,但是可以快速地在鏈表中間插入和刪除元素。 不僅如此,LinkedList 還可以用作棧、隊列和雙向隊列。
**3. Queue**
- LinkedList:可以用它來實現(xiàn)雙向隊列。
- PriorityQueue:基于堆結構實現(xiàn),可以用它來實現(xiàn)優(yōu)先隊列。
# 二、Map

- TreeMap:基于紅黑樹實現(xiàn)。
- HashMap:基于哈希表實現(xiàn)。
- HashTable:和 HashMap 類似,但它是線程安全的, 這意味著同一時刻多個線程可以同時寫入 HashTable 并且不會導致數(shù)據(jù)不一致。 它是遺留類,不應該去使用它。現(xiàn)在可以使用 ConcurrentHashMap 來支持線程安全, 并且 ConcurrentHashMap 的效率會更高,因為 ConcurrentHashMap 引入了分段鎖。
- LinkedHashMap:使用雙向鏈表來維護元素的順序,順序為插入順序或者最近最少使用(LRU)順序。
來自 “ ITPUB博客 ” ,鏈接:http://blog.itpub.net/69964492/viewspace-2684099/,如需轉載,請注明出處,否則將追究法律責任。
總結
以上是生活随笔為你收集整理的java容器详解_详解Java 容器(第①篇)——概览的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python中的数字类型格式与运算,py
- 下一篇: sdr 软件_【火腿专题】购买软件定义无