這篇文章主要給大家介紹了關(guān)于Java中遍歷Map集合的5種方式主慰,文中通過示例代碼介紹的非常詳細摇展,對大家的學習或者工作具有一定的參考學習價值房蝉,需要的朋友們下面隨著小編來一起學習學習吧
方式一 通過Map.keySet使用iterator遍歷
@Test
public void testHashMap1() {
Map<Integer, String> map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫");
map.put(003, "Vue");
System.out.println(map);
// 通過Map.keySet使用iterator遍歷key,然后通過key得到對應的value值
Iterator<Integer> iterator = map.keySet().iterator();
while (iterator.hasNext()) {
Integer key = iterator.next();
String value = map.get(key);
System.out.println("key = " + key + ", value = " + value);
}
}
結(jié)果:
{1=Java, 2=數(shù)據(jù)庫, 3=Vue}
key = 1, value = Java
key = 2, value = 數(shù)據(jù)庫
key = 3, value = Vue
方式二 通過Map.entrySet使用iterator遍歷
@Test
public void testHashMap2() {
Map<Integer, String> map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫");
map.put(003, "Vue");
System.out.println(map);
// 通過Map.entrySet使用iterator遍歷key和value颊郎;注意 Set entrySet():返回所有key-value對構(gòu)成的Set集合
Iterator<Map.Entry<Integer, String>> entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry<Integer, String> entry = entries.next();
System.out.println(entry);
}//加入Java開發(fā)交流君樣:756584822一起吹水聊天
}
結(jié)果:
{1=Java, 2=數(shù)據(jù)庫, 3=Vue}
1=Java
2=數(shù)據(jù)庫
3=Vue
方式三 通過Map.keySet遍歷
@Test
public void testHashMap3() {
Map<Integer, String> map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫");
map.put(003, "Vue");
System.out.println(map);
// 通過Map.keySet遍歷key,然后通過key得到對應的value值
for (Integer key : map.keySet()) {
System.out.println("key = " + key + ", value = " + map.get(key));
}
}
結(jié)果:
{1=Java, 2=數(shù)據(jù)庫, 3=Vue}
key = 1, value = Java
key = 2, value = 數(shù)據(jù)庫
key `= 3, value = Vue
方式四 通過For-Each迭代entries叔遂,使用Map.entrySet遍歷
@Test
public void testHashMap4() {
Map<Integer, String> map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫");
map.put(003, "Vue");
System.out.println(map);
// 使用For-Each迭代entries他炊,通過Map.entrySet遍歷key和value
for (Map.Entry<Integer, String> entry : map.entrySet()) {
System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
}
}//加入Java開發(fā)交流君樣:756584822一起吹水聊天
{1=Java, 2=數(shù)據(jù)庫, 3=Vue}
key = 1, value = Java
key = 2, value = 數(shù)據(jù)庫
key = 3, value = Vue
方式五 使用lambda表達式forEach遍歷
@Test
public void testHashMap5() {
Map<Integer, String> map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫");
map.put(003, "Vue");
System.out.println(map);
// 使用lambda表達式forEach遍歷
map.forEach((k, v) -> System.out.println("key = " + k + ", value = " + v));
}//加入Java開發(fā)交流君樣:756584822一起吹水聊天
forEach 源碼
default void forEach(BiConsumer<? super K, ? super V> action) {
Objects.requireNonNull(action);
for (Map.Entry<K, V> entry : entrySet()) {
K k;
V v;
try {
k = entry.getKey();
v = entry.getValue();
} catch(IllegalStateException ise) {
// this usually means the entry is no longer in the map.
throw new ConcurrentModificationException(ise);
}//加入Java開發(fā)交流君樣:756584822一起吹水聊天
action.accept(k, v);
}
}
從源碼可以看到,這種新特性就是在傳統(tǒng)的迭代方式上加了一層殼已艰,但是讓代碼變得更加簡單痊末。(開發(fā)中推薦使用)
總結(jié)
推薦使用 entrySet 遍歷 Map 類集合 KV (文章中的第四種方式),而不是 keySet 方式進行遍歷哩掺。
keySet 其實是遍歷了 2 次凿叠,第一次是轉(zhuǎn)為 Iterator 對象,第二次是從 hashMap 中取出 key 所對應的 value值嚼吞。而 entrySet 只是遍歷了一次盒件,就把 key 和 value 都放到了 entry 中,效率更高舱禽。
values()返回的是 V 值集合炒刁,是一個 list 集合對象;keySet()返回的是 K 值集合誊稚,是一個 Set 集合對象翔始;entrySet()返回的是 K-V 值組合集合。