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

 

點擊關注,第一時間了解華為雲新鮮技術~


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2024 CODEPRJ.COM