Java中Map常用方法總結(jié)以及遍歷方式的匯總
一滴劲、整理:
看到array鲁捏,就要想到角標(biāo)动羽。
看到link疯趟,就要想到first,last隘庄。
看到hash,就要想到hashCode,equals.
看到tree,就要想到兩個(gè)接口。Comparable蟆技,Comparator眶蕉。
二弄痹、Map與Collection在集合框架中屬并列存在
1.Map存儲的是鍵值對
2.Map存儲元素使用put方法,Collection使用add方法
3.Map集合沒有直接取出元素的方法,而是先轉(zhuǎn)成Set集合,在通過迭代獲取元素
4.Map集合中鍵要保證唯一性
也就是Collection是單列集合, Map 是雙列集合觅赊。
總結(jié):
Map一次存一對元素, Collection 一次存一個(gè)。Map 的鍵不能重復(fù),保證唯一勋陪。
Map 一次存入一對元素,是以鍵值對的形式存在.鍵與值存在映射關(guān)系.一定要保證鍵的唯一性.
三硫兰、Map中常見方法:
1呻粹、添加:
1、V put(K key, V value) (可以相同的key值腮郊,但是添加的value值會(huì)覆蓋前面的,返回值是前一個(gè)泵三,如果沒有就返回null)
2、putAll(Map<? extends K,? extends V> m) 從指定映射中將所有映射關(guān)系復(fù)制到此映射中(可選操作)弛饭。
2、刪除
1蜕窿、remove() 刪除關(guān)聯(lián)對象谋逻,指定key對象
2、clear() 清空集合對象
3桐经、獲取
1毁兆、value get(key); 可以用于判斷鍵是否存在的情況。當(dāng)指定的鍵不存在的時(shí)候阴挣,返回的是null气堕。
3、判斷:
1、boolean isEmpty() 長度為0返回true否則false
2茎芭、boolean containsKey(Object key) 判斷集合中是否包含指定的key
3揖膜、boolean containsValue(Object value) 判斷集合中是否包含指定的value
4、長度:
Int size()
四梅桩、遍歷Map的方式:
1壹粟、將map 集合中所有的鍵取出存入set集合。
Set<K> keySet() 返回所有的key對象的Set集合宿百,再通過get方法獲取鍵對應(yīng)的值趁仙。
2、 values() 犀呼,獲取所有的值.
Collection<V> values()不能獲取到key對象
3幸撕、 Map.Entry對象 推薦使用 重點(diǎn)
Set<Map.Entry<k,v>> entrySet() 將map 集合中的鍵值映射關(guān)系打包成一個(gè)對象。
Map.Entry對象通過Map.Entry 對象的getKey外臂,getValue獲取其鍵和值坐儿。
第一種方式:使用keySet
將Map轉(zhuǎn)成Set集合(keySet()),通過Set的迭代器取出Set集合中的每一個(gè)元素(Iterator)就是Map集合中的所有的鍵宋光,再通過get方法獲取鍵對應(yīng)的值貌矿。
第二種方式: 通過values 獲取所有值,不能獲取到key對象
第三種方式: Map.Entry
public static interface Map.Entry<K,V> 通過Map中的entrySet()方法獲取存放Map.Entry<K,V>對象的Set集合。
Set<Map.Entry<K,V>> entrySet() 面向?qū)ο蟮乃枷雽ap集合中的鍵和值映射關(guān)系打包為一個(gè)對象罪佳,就是Map.Entry逛漫,將該對象存入Set集合,Map.Entry是一個(gè)對象赘艳,那么該對象具備的getKey酌毡,getValue獲得鍵和值。