Map集合:
1.Map集合與Collection集合的區別:
1.Collection中的集合,元素是孤立存在的,向集合中存儲元素採用一個個元素的方式存儲。
2.Map中的集合1,元素是成對存在的,每個元素由鍵合值兩個部分組成,通過鍵可以找到對應的值。
3.Collection中的集合稱爲單列集合,而Map中的集合稱爲雙列集合。
4.Map中的集合不能包含重複的鍵,但可以有重複值;每個鍵只能有一個值。
2.Map中常用的子類:
。HashMap:存儲數據採用的哈希表結構,元素的存儲順序不能保持一致。由於要保證鍵的唯一,不重複,所以要重寫hashCode()方法和equal()方法。
。LinkHashMap:通過鏈表結構可以保證元素的存儲順序一致,同樣也要重寫hashCode()方法和equals()方法。
3.Map接口中的常用方法:
public v put(K key,V value): 把指定的鍵與指定的值添加到Map集合中。
public v remove(Object key): 把指定的鍵對應的元素在對應的集合中刪除,返回的是被刪除的元素的值
public V get(Object key) :根據指定的鍵在Map集合中獲取對應的值
public boolean containsKey(Object key) :判斷當前對象是否存在於集合中
public Set<K> keySet() :獲取Map集合中的所有鍵,存儲到set集合中
public Set<Map.Entry<K,V>> entrySet()
: 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。
Map接口的方法演示:
import java.util.HashMap;
public class MapDemo {
public static void main(String[] args) {
HashMap<String,String> hashMap = new HashMap<String,String>();
hashMap.put("刀鋒之影", "泰隆");
hashMap.put("刀鋒意志", "艾瑞莉婭");
hashMap.put("放逐之刃", "瑞文");
hashMap.put("疾風劍豪", "亞索");
System.out.println(hashMap);
System.out.println("--------------------------------");
System.out.println(hashMap.remove("放逐之刃"));
System.out.println(hashMap);
System.out.println("--------------------------------");
System.out.println(hashMap.get("疾風劍豪"));
}
}
打印結果:
{刀鋒意志=艾瑞莉婭, 疾風劍豪=亞索, 放逐之刃=瑞文, 刀鋒之影=泰隆}
--------------------------------
瑞文
{刀鋒意志=艾瑞莉婭, 疾風劍豪=亞索, 刀鋒之影=泰隆}
--------------------------------
亞索
注:使用put方法時,若指定的鍵(key)在集合中沒有,則新增;若指定的鍵在集合中存在,把指定鍵對應的值,替換成對應的新值。
4.Map集合遍歷鍵找值得方式:
鍵找值方式:即通過元素中的鍵,獲取鍵所對應的值
分析步驟:
- 獲取Map中所有的鍵,由於鍵是唯一的,所以返回一個Set集合存儲所有的鍵。方法提示:
keyset()
- 遍歷鍵的Set集合,得到每一個鍵。
- 根據鍵,獲取鍵所對應的值。方法提示:
get(K key)
代碼演示:
import java.util.HashMap;
import java.util.Set;
public class MapDemo {
public static void main(String[] args) {
HashMap<String,String> hashMap = new HashMap<String,String>();
hashMap.put("刀鋒之影", "泰隆");
hashMap.put("刀鋒意志", "艾瑞莉婭");
hashMap.put("放逐之刃", "瑞文");
hashMap.put("疾風劍豪", "亞索");
//獲取所有鍵, 獲取鍵值
Set<String> keySet = hashMap.keySet();
//獲取對應的值
for(String key : keySet) {
System.out.println(key+":"+hashMap.get(key));
}
}
}
打印結果:
刀鋒意志:艾瑞莉婭
疾風劍豪:亞索
放逐之刃:瑞文
刀鋒之影:泰隆
5.Entry鍵值對對象
我們已經知道,Map
中存放的是兩種對象,一種稱爲key(鍵),一種稱爲value(值),它們在在Map
中是一一對應關係,這一對對象又稱做Map
中的一個Entry(項)
。Entry
將鍵值對的對應關係封裝成了對象。即鍵值對對象,這樣我們在遍歷Map
集合時,就可以從每一個鍵值對(Entry
)對象中獲取對應的鍵與對應的值。
既然Entry表示了一對鍵和值,那麼也同樣提供了獲取對應鍵和對應值得方法:
public K getKey()
:獲取Entry對象中的鍵。public V getValue()
:獲取Entry對象中的值。
在Map集合中也提供了獲取所有Entry對象的方法:
public Set<Map.Entry<K,V>> entrySet()
: 獲取到Map集合中所有的鍵值對對象的集合(Set集合)。
6.Map集合遍歷鍵值對方式:
鍵值對方式:即通過集合中每個鍵值對(Entry)對象,獲取鍵值對(Entry)對象中的鍵與值。
操作步驟:
- 獲取Map集合中,所有的鍵值對(Entry)對象,以Set集合形式返回。方法提示:
entrySet()
。 - 遍歷包含鍵值對(Entry)對象的Set集合,得到每一個鍵值對(Entry)對象。
- 通過鍵值對(Entry)對象,獲取Entry對象中的鍵與值。 方法提示:
getkey() getValue()
案例演示:
import java.util.HashMap;
import java.util.Map.Entry;
import java.util.Set;
public class MapDemo {
public static void main(String[] args) {
HashMap<String,String> hashMap = new HashMap<String,String>();
hashMap.put("刀鋒之影", "泰隆");
hashMap.put("刀鋒意志", "艾瑞莉婭");
hashMap.put("放逐之刃", "瑞文");
hashMap.put("疾風劍豪", "亞索");
//獲取所有的 entry對象 entrySet
Set<Entry<String,String>> entrySet = hashMap.entrySet();
//遍歷得到每一個entrySet對象
for(Entry<String,String> entry : entrySet) {
System.out.println(entry.getKey()+":"+entry.getValue());
}
}
}
打印結果:
刀鋒意志:艾瑞莉婭
疾風劍豪:亞索
放逐之刃:瑞文
刀鋒之影:泰隆
注:Map集合不能直接使用迭代器或者foreach進行遍歷。但是轉成Set之後就可以使用了。