java 集合----Map、Collection
接口:紅色;實(shí)現(xiàn)類:黑色字體
一、 Collection集合
Collection
|_____Set(HashSet)
| |_____SortedSet(TreeSet)
|_____List(ArrayList,LinkedList,Vector )
Collection:集合層次中的根接口,JDK沒(méi)有提供這個(gè)接口的實(shí)現(xiàn)類。
List: 有序(按照放入的順序)、可以重復(fù)、有下標(biāo)。
Set:無(wú)序、不可以重復(fù)、無(wú)下標(biāo)。
SortedSet:是Set接口的子接口,SortedSet中的元素是有序的(按字母升序)。
通過(guò) Comparable接口的compareTo方法,實(shí)現(xiàn)元素是有序的。放入的元素都必須實(shí)現(xiàn) Comparable 接口(或者被指定的Comparator 所接受)。
List接口的實(shí)現(xiàn)類的區(qū)別:
ArrayList :本質(zhì)上是一個(gè)數(shù)組。線程不安全。查詢(get/set)快,增刪(add/remove)慢。
LinkedList: 本質(zhì)上是一個(gè)雙向鏈表。線程不安全。查詢(get/set)慢,增刪(add/remove)快。
Vector :和ArrayList幾乎是完全相同的,唯一的區(qū)別在于Vector是同步類(synchronized),是線程安全的。
二、Map集合
Map(HashMap,Hashtable)
|_____SortedMap(TreeMap)
Map:存儲(chǔ)的是key-value對(duì),不能包含重復(fù)的key,可以有重復(fù)的value。
SortedMap:Map的子接口SortedMap是一個(gè)按升序排列key的Map。
HashMap、Hashtable和TreeMap的區(qū)別
HashMap :線程不安全。key和value都可以是null。元素是無(wú)序的。底層是哈希表數(shù)據(jù)結(jié)構(gòu)。
Hashtable:線程安全。key和value都不可以是null。元素是無(wú)序的。底層是哈希表數(shù)據(jù)結(jié)構(gòu)。
TreeMap:線程不安全。key和value都不可以是null。元素是有序的(按字母升序)。底層是二叉樹(shù)數(shù)據(jù)結(jié)構(gòu)。
三、Map的key、Set 的值如何實(shí)現(xiàn)不重復(fù)
Map 放相同的key,之后的覆蓋之前的
Map map=new HashMap();
map.put(“name”,”張三”);
map.put(“name”,”王五”);------有效,覆蓋之前的
Set放相同的元素時(shí),第一個(gè)是有效的,之后的不會(huì)被放入
Set set=new HashSet();
set.add(“111”);---有效
set.add(“222”);----判斷已有,不會(huì)放入
1、HashMap 的 put 與 HashSet 的 add
由于 HashSet 的 add() 方法添加集合元素時(shí)實(shí)際上轉(zhuǎn)變?yōu)檎{(diào)用 HashMap 的 put() 方法來(lái)添加 key-value 對(duì)。HashMap 的 put() 方法首先調(diào)用.hashCode() 判斷返回值相等,如果返回值相等則再通過(guò) equals 比較也返回 true,最終認(rèn)為key對(duì)象是相等的已經(jīng)在HashMap中存在了。
2、TreeMap 的 put 與 TreeSet 的 add
TreeMap中調(diào)用put方法添加鍵值時(shí),調(diào)用對(duì)象的它的 compareTo(或 compare)方法對(duì)所有鍵進(jìn)行比較,此方法飯回0,則認(rèn)為兩個(gè)鍵就是相等的。
TreeSet添加元素的時(shí)候,調(diào)用compareTo或compare方法來(lái)定位元素的位置,也就是返回compareTo或compare返回0則認(rèn)為是同一個(gè)位置的元素,即相同元素
- Java?HashTable與Collections.synchronizedMap源碼深入解析
- 淺談collection標(biāo)簽的oftype屬性能否為java.util.Map
- JAVA容器集合全面解析(Collection和Map)
- Java中Collection、List、Set、Map之間的關(guān)系總結(jié)
- 如何解決Mybatis--java.lang.IllegalArgumentException: Result Maps collection already contains value for X
- 淺談Java中常用數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)類 Collection和Map
- Java Map集合與Collection類的使用詳解
相關(guān)文章
springboot 自定義異常并捕獲異常返給前端的實(shí)現(xiàn)代碼
在開(kāi)發(fā)中,如果用try catch的方式,每個(gè)方法都需要單獨(dú)實(shí)現(xiàn),為了方便分類異常,返回給前端,采用了@ControllerAdvice注解和繼承了RuntimeException的方式來(lái)實(shí)現(xiàn),具體實(shí)現(xiàn)內(nèi)容跟隨小編一起看看吧2021-11-11Java實(shí)現(xiàn)單鏈表反轉(zhuǎn)的多種方法總結(jié)
這篇文章主要給大家介紹了關(guān)于Java實(shí)現(xiàn)單鏈表反轉(zhuǎn)的多種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04Java線程的調(diào)度與優(yōu)先級(jí)詳解
這篇文章主要為大家詳細(xì)介紹了Java線程的調(diào)度與優(yōu)先級(jí),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03Java7和Java8中的ConcurrentHashMap原理解析
這篇文章主要介紹了Java7和Java8中的ConcurrentHashMap原理解析,對(duì)ConcurrentHashMap感興趣的讀者,一定要好好看一下2021-04-04Intellij IDEA基于Springboot的遠(yuǎn)程調(diào)試(圖文)
這篇文章主要介紹了Intellij IDEA基于Springboot的遠(yuǎn)程調(diào)試(圖文),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10Mybatis?TypeHandler接口及繼承關(guān)系示例解析
這篇文章主要為大家介紹了Mybatis?TypeHandler接口及繼承關(guān)系示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02使用Postman傳遞arraylist數(shù)據(jù)給springboot方式
這篇文章主要介紹了使用Postman傳遞arraylist數(shù)據(jù)給springboot方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12