您好,登錄后才能下訂單哦!
這篇文章主要介紹了Java中遍歷Map集合的方法有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
@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
@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
@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
@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
@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 方法(文章中的第五種方式)。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“Java中遍歷Map集合的方法有哪些”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。