java核心(十五):List、Set、Map功能分析
生活随笔
收集整理的這篇文章主要介紹了
java核心(十五):List、Set、Map功能分析
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、List、Set、Map三者關系分析 解釋一:List與Set的區別 List和Set都是接口繼承于Collection接口; 最大的不同就是List是可以重復的。而Set是不能重復的; List接口有三個實現類:LinkedList、ArrayList、Vector?,Set接口有兩個實現類:HashSet(底層由HashMap實現)、TreeSet、LinkedHashSet; List適合經常追加數據、插入、刪除數據。但隨機取數效率比較低; Set適合經常地隨機儲存、插入、刪除。但是在遍歷時效率比較低。 解釋二:Set與Map Set對每個對象只接受一次,并使用自己內部的排序方法(通常,你只關心某個元素是否屬于Set,而不關心它的順序--否則應該使用List)。 Map同樣對每個元素保存一份,但這是基于"鍵"的,Map也有內置的排序,因而不關心元素添加的順序。如果添加元素的順序對你很重要,應該使用LinkedHashSet或者LinkedHashMap. 總結: List有順序有重復沒有排序,set無重復有排序。 map的key也和set一樣。 如果想跟List一樣需要有插入元素的順序,請使用LinkedHashSet或者LinkedHashMap。 容器類僅能持有對象引用(指向對象的指針),而不是將對象信息copy一份至數列某位置。 Collection沒有get()方法,只能通過iterator()遍歷元素。Set和Collection擁有一模一樣的接口。List可以通過get()方法來一次取出一個元素。 一般使用ArrayList。用LinkedList構造堆棧stack、隊列queue。 HashMap會利用對象的hashCode來快速找到key。說明:哈希碼就是將對象的信息經過一些轉變形成一個獨一無二的int值,這個值存儲在一個array中。我們都知道所有存儲結構中,array查找速度是最快的,所以,可以加速查找。發生碰撞時,讓array指向多個values,即,數組每個位置上又生成一個梿表。 LinkedList、ArrayList、HashSet是非線程安全的,Vector是線程安全的; HashMap是非線程安全的,HashTable是線程安全的; 二、List的功能方法 1、List接口及實現類 實際上有兩種List: 一種是基本的ArrayList,其優點在于隨機訪問元素,另一種是更強大的LinkedList,它并不是為快速隨機訪問設計的,而是具有一套更通用的方法。 List : 次序是List最重要的特點:它保證維護元素特定的順序。List為Collection添加了許多方法,使得能夠向List中間插入與移除元素(這只推薦LinkedList使用。)一個List可以生成ListIterator,使用它可以從兩個方向遍歷List,也可以從List中間插入和移除元素。 ArrayList : 由數組實現的List。允許對元素進行快速隨機訪問,但是向List中間插入與移除元素的速度很慢。ListIterator只應該用來由后向前遍歷ArrayList,而不是用來插入和移除元素。因為那比LinkedList開銷要大很多。 LinkedList : 對順序訪問進行了優化,向List中間插入與刪除的開銷并不大。隨機訪問則相對較慢。(使用ArrayList代替。)還具有下列方法:addFirst(), addLast(), getFirst(), getLast(), removeFirst() 和 removeLast(), 這些方法 (沒有在任何接口或基類中定義過)使得LinkedList可以當作堆棧、隊列和雙向隊列使用。 2、ArrayList 與 LinkedList 的區別和適用場景 (1)Arraylist :
作者:安卓之夜 原文:https://blog.csdn.net/qq_22118507/article/details/51576319
特別說明
- 優點:ArrayList是實現了基于動態數組的數據結構,因為地址連續,一旦數據存儲好了,查詢操作效率會比較高(在內存里是連著放的)。
- 缺點:因為地址連續,?ArrayList要移動數據,所以插入和刪除操作效率比較低。???
- 優點:LinkedList基于鏈表的數據結構,地址是任意的,所以在開辟內存空間的時候不需要等一個連續的地址,對于新增和刪除操作add和remove,LinedList比較占優勢。LinkedList?適用于要頭尾操作或插入指定位置的場景
- 缺點:因為LinkedList要移動指針,所以查詢操作性能比較低。
- ?當需要對數據進行多次訪問的情況下選用ArrayList,當需要對數據進行多次增加刪除修改時采用LinkedList。
- TreeSet?是二差樹(紅黑樹的樹據結構)實現的,Treeset中的數據是自動排好序的,不允許放入null值?
- HashSet?是哈希表實現的,HashSet中的數據是無序的,可以放入null,但只能放入一個null,兩者中的值都不能重復,就如數據庫中唯一約束?
- HashSet要求放入的對象必須實現HashCode()方法,放入的對象,是以hashcode碼作為標識的,而具有相同內容的String對象,hashcode是一樣,所以放入的內容不能重復。但是同一個類的對象可以放入不同的實例
- HashSet是基于Hash算法實現的,其性能通常都優于TreeSet。為快速查找而設計的Set,我們通常都應該使用HashSet。
- 在我們需要排序的功能時,我們才使用TreeSet。
? 2、HashMap與TreeMap、HashTable的區別及適用場景
(1)HashMap :?
- HashMap?非線程安全??
- HashMap:基于哈希表實現。使用HashMap要求添加的鍵類明確定義了hashCode()和equals()[可以重寫hashCode()和equals()],為了優化HashMap空間的使用,您可以調優初始容量和負載因子。?
? (2)TreeMap :?
- TreeMap:非線程安全基于紅黑樹實現。
- TreeMap沒有調優選項,因為該樹總處于平衡狀態。?
? (3)適用場景分析:
- HashMap和HashTable:HashMap去掉了HashTable的contains方法,但是加上了containsValue()和containsKey()方法。HashTable同步的,而HashMap是非同步的,效率上比HashTable要高。HashMap允許空鍵值,而HashTable不允許。
- HashMap:適用于Map中插入、刪除和定位元素。?
- Treemap:適用于按自然順序或自定義順序遍歷鍵(key)。
(3)推薦閱讀:HashMap的底層實現
-
漫畫:什么是HashMap?
-
高并發下的HashMap,在ReHash的時候可能會出現鏈表環,導致查詢可能會出現死循環
作者:安卓之夜 原文:https://blog.csdn.net/qq_22118507/article/details/51576319
?
轉載于:https://www.cnblogs.com/newbie27/p/10568784.html
總結
以上是生活随笔為你收集整理的java核心(十五):List、Set、Map功能分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 比赛注意事项
- 下一篇: 实验1 C语言开发环境使用和数据类型、运