Java中遍历Map集合的五种方式[通俗易懂]

2022-07-25 12:43:23 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

文章目录
  • 方式一 通过Map.keySet使用iterator遍历
  • 方式二 通过Map.entrySet使用iterator遍历
  • 方式三 通过Map.keySet遍历
  • 方式四 通过For-Each迭代entries,使用Map.entrySet遍历
  • 方式五 使用lambda表达式forEach遍历
  • 总结

方式一 通过Map.keySet使用iterator遍历

代码语言:javascript复制
@Test
public void testHashMap1() { 
   
    Map<Integer, String> map = new HashMap<>();
    map.put(001, "Java");
    map.put(002, "数据库");
    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);
    }
}

结果:

代码语言:javascript复制
{ 
   1=Java, 2=数据库, 3=Vue}
key = 1, value = Java
key = 2, value = 数据库
key = 3, value = Vue

方式二 通过Map.entrySet使用iterator遍历

代码语言:javascript复制
@Test
public void testHashMap2() { 
   
    Map<Integer, String> map = new HashMap<>();
    map.put(001, "Java");
    map.put(002, "数据库");
    map.put(003, "Vue");
    System.out.println(map);

    // 通过Map.entrySet使用iterator遍历key和value;注意 Set entrySet():返回所有key-value对构成的Set集合
    Iterator<Map.Entry<Integer, String>> entries = map.entrySet().iterator();
    while (entries.hasNext()) { 
   
        Map.Entry<Integer, String> entry = entries.next();
        System.out.println(entry);
    }
}

结果:

代码语言:javascript复制
{ 
   1=Java, 2=数据库, 3=Vue}
1=Java
2=数据库
3=Vue

方式三 通过Map.keySet遍历

代码语言:javascript复制
@Test
public void testHashMap3() { 
   
    Map<Integer, String> map = new HashMap<>();
    map.put(001, "Java");
    map.put(002, "数据库");
    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));
    }
}

结果:

代码语言:javascript复制
{ 
   1=Java, 2=数据库, 3=Vue}
key = 1, value = Java
key = 2, value = 数据库
key = 3, value = Vue

方式四 通过For-Each迭代entries,使用Map.entrySet遍历

代码语言:javascript复制
@Test
public void testHashMap4() { 
   
    Map<Integer, String> map = new HashMap<>();
    map.put(001, "Java");
    map.put(002, "数据库");
    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());
    }
}
代码语言:javascript复制
{ 
   1=Java, 2=数据库, 3=Vue}
key = 1, value = Java
key = 2, value = 数据库
key = 3, value = Vue

方式五 使用lambda表达式forEach遍历

代码语言:javascript复制
@Test
public void testHashMap5() { 
   
    Map<Integer, String> map = new HashMap<>();
    map.put(001, "Java");
    map.put(002, "数据库");
    map.put(003, "Vue");
    System.out.println(map);

	// 使用lambda表达式forEach遍历
    map.forEach((k, v) -> System.out.println("key = "   k   ", value = "   v));
}

forEach 源码

代码语言:javascript复制
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);
            }
            action.accept(k, v);
        }
    }

从源码可以看到,这种新特性就是在传统的迭代方式上加了一层壳,但是让代码变得更加简单。(开发中推荐使用

总结

推荐使用 entrySet 遍历 Map 类集合 KV (文章中的第四种方式),而不是 keySet 方式进行遍历。

keySet 其实是遍历了 2 次,第一次是转为 Iterator 对象,第二次是从 hashMap 中取出 key 所对应的 value值。而 entrySet 只是遍历了一次,就把 key 和 value 都放到了 entry 中,效率更高。

values()返回的是 V 值集合,是一个 list 集合对象;keySet()返回的是 K 值集合,是一个 Set 集合对象;entrySet()返回的是 K-V 值组合集合。

如果是 JDK8,推荐使用Map.forEach 方法(文章中的第五种方式)。


由于水平有限,本博客难免有不足,恳请各位大佬不吝赐教!

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/127295.html原文链接:https://javaforall.cn

0 人点赞