小言_互联网的博客

Java之五种遍历Map集合的方式

289人阅读  评论(0)
摘要:在java中所有的map都实现了Map接口,因此所有的Map都可以用以下的方式去遍历。

在java中所有的map都实现了Map接口,因此所有的Map都可以用以下的方式去遍历。这篇文章主要给大家介绍了关于Java中遍历Map集合的5种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面一起学习学习吧。

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


  
  1. @Test
  2. public void testHashMap1() {
  3. Map< Integer, String> map = new HashMap<>();
  4. map.put( 001, "Java");
  5. map.put( 002, "数据库");
  6. map.put( 003, "Vue");
  7. System.out.println(map);
  8. // 通过Map.keySet使用iterator遍历key,然后通过key得到对应的value值
  9. Iterator< Integer> iterator = map.keySet(). iterator();
  10. while ( iterator.hasNext()) {
  11. Integer key = iterator.next();
  12. String value = map.get(key);
  13. System.out.println( "key = " + key + ", value = " + value);
  14. }
  15. }

结果:


  
  1. { 1 =Java, 2 =数据库, 3 =Vue}
  2. key = 1 , value = Java
  3. key = 2 , value = 数据库
  4. key = 3 , value = Vue

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


  
  1. @Test
  2. public void testHashMap2() {
  3. Map< Integer, String> map = new HashMap<>();
  4. map.put( 001, "Java");
  5. map.put( 002, "数据库");
  6. map.put( 003, "Vue");
  7. System.out.println(map);
  8. // 通过Map.entrySet使用iterator遍历key和value;注意 Set entrySet():返回所有key-value对构成的Set集合
  9. Iterator<Map.Entry< Integer, String>> entries = map.entrySet(). iterator();
  10. while (entries.hasNext()) {
  11. Map.Entry< Integer, String> entry = entries.next();
  12. System.out.println(entry);
  13. }
  14. }

结果:


  
  1. { 1 =Java, 2 =数据库, 3 =Vue}
  2. 1 =Java
  3. 2 =数据库
  4. 3 =Vue

方式三 通过Map.keySet遍历


  
  1. @ Test
  2. public void testHashMap3 () {
  3. Map<Integer, String> map = new HashMap<>();
  4. map.put( 001, "Java");
  5. map.put( 002, "数据库");
  6. map.put( 003, "Vue");
  7. System.out.println( map);
  8. // 通过Map.keySet遍历key,然后通过key得到对应的value值
  9. for (Integer key : map.keySet()) {
  10. System.out.println( "key = " + key + ", value = " + map.get(key));
  11. }
  12. }

结果:


  
  1. { 1 =Java, 2 =数据库, 3 =Vue}
  2. key = 1 , value = Java
  3. key = 2 , value = 数据库
  4. key = 3 , value = Vue

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


  
  1. @ Test
  2. public void testHashMap4 () {
  3. Map<Integer, String> map = new HashMap<>();
  4. map.put( 001, "Java");
  5. map.put( 002, "数据库");
  6. map.put( 003, "Vue");
  7. System.out.println( map);
  8. // 使用For-Each迭代entries,通过Map.entrySet遍历key和value
  9. for (Map.Entry<Integer, String> entry : map.entrySet()) {
  10. System.out.println( "key = " + entry.getKey() + ", value = " + entry.getValue());
  11. }
  12. }

结果


  
  1. { 1 =Java, 2 =数据库, 3 =Vue}
  2. key = 1 , value = Java
  3. key = 2 , value = 数据库
  4. key = 3 , value = Vue

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


  
  1. @ Test
  2. public void testHashMap5 () {
  3. Map<Integer, String> map = new HashMap<>();
  4. map.put( 001, "Java");
  5. map.put( 002, "数据库");
  6. map.put( 003, "Vue");
  7. System.out.println( map);
  8. // 使用lambda表达式forEach遍历
  9. map.forEach((k, v) -> System.out.println( "key = " + k + ", value = " + v));
  10. }

forEach 源码


  
  1. default void forEach(BiConsumer<? super K, ? super V> action) {
  2. Objects.requireNonNull(action);
  3. for ( Map.Entry<K, V> entry : entrySet()) {
  4. K k;
  5. V v;
  6. try {
  7. k = entry.getKey();
  8. v = entry.getValue();
  9. } catch(IllegalStateException ise) {
  10. // this usually means the entry is no longer in the map.
  11. throw new ConcurrentModificationException(ise);
  12. }
  13. action.accept(k, v);
  14. }
  15. }

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

总结

推荐使用 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 方法(文章中的第五种方式)。

本文分享自华为云社区《Java中遍历Map集合的五种方式》,原文作者:王小贰 。

 

点击关注,第一时间了解华为云新鲜技术~


转载:https://blog.csdn.net/devcloud/article/details/113504135
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场