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


    摘要:在java中所有的map都实现了Map接口,因此所有的Map都可以用以下的方式去遍历。

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

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

    @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);
        }
    }

    结果:

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

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

    @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);
        }
    }

    结果:

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

    方式三 通过Map.keySet遍历

    @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));
        }
    }

    结果:

    {1=Java, 2=数据库, 3=Vue}
    key = 1, value = Java
    key = 2, value = 数据库
    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, "数据库");
        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());
        }
    }

    结果

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

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

    @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 源码

    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://zhangxy.blog.csdn.net/article/details/113336560

     

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

  • 相关阅读:
    linux中mysql,mongodb,redis,hbase数据库操作
    hbase数据库操作
    hdfs基本操作
    linux及hadoop基本操作
    创建有关hbase数据库的项目时所遇到的问题
    数据科学与大数据
    《TCP/IP详解卷1:协议》——第2章:链路层(转载)
    《TCP/IP详解卷1:协议》——第1章:概述(转载)
    深入理解计算机操作系统——第9章:缓存,存储器管理
    深入理解计算机操作系统——第9章:物理和虚拟寻址,地址空间
  • 原文地址:https://www.cnblogs.com/huaweiyun/p/14355761.html
Copyright © 2020-2023  润新知