方法一 通過Map.entrySet遍歷key和value,在for-each循環中使用entries來遍歷.推薦,尤其是容量大時
這是最常見的並且在大多數情況下也是最可取的遍歷方式。在鍵值都需要時使用。
Map<Integer, Integer> map = new HashMap<Integer, Integer>(); for (Map.Entry<Integer, Integer> entry : map.entrySet()) { System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue()); }
方法二、通過Map.keySet遍歷key,通過鍵找值value遍歷(效率低),普遍使用,二次取值
Map<Integer, Integer> map = new HashMap<Integer, Integer>(); for (Integer key : map.keySet()) { Integer value = map.get(key); System.out.println("Key = " + key + ", Value = " + value); }
方法三 如果只需要map中的鍵或者值,你可以通過Map.keySet或Map.values來實現遍歷,而不是用entrySet。在for-each循環中遍歷keys或values。
Map<Integer, Integer> map = new HashMap<Integer, Integer>(); //遍歷map中的鍵 for (Integer key : map.keySet()) { System.out.println("Key = " + key); } //遍歷map中的值 for (Integer value : map.values()) { System.out.println("Value = " + value); }
方法四:通過Map.entrySet使用iterator遍歷key和value
Map<Integer, Integer> map = new HashMap<Integer, Integer>(); Iterator<Map.Entry<Integer, Integer>> entries = map.entrySet().iterator(); while (entries.hasNext()) { Map.Entry<Integer, Integer> entry = entries.next(); System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue()); }
全部代碼:
public static void main(String[] args) { init(); traversal(); } // HashMap按照哈希算法來存取鍵對象,有很好的存取性能 private static HashMap<String, String> hMap = new HashMap<>(); // TreeMap實現了SortedMap接口,能對鍵對象進行排序。支持自然排序和客戶化排序兩種方式。 private static TreeMap<String, String> tMap = new TreeMap<>(); // map的賦值 public static void init() { hMap.put("1", "value1"); hMap.put("2", "value2"); hMap.put("3", "value3"); } // map的遍歷 public static void traversal() { // 第一種:普遍使用,二次取值 System.out.println("通過Map.keySet遍歷key和value:"); for (String key : hMap.keySet()) { System.out.println("key= " + key + " and value= " + hMap.get(key)); } // 第二種 System.out.println("通過Map.entrySet使用iterator遍歷key和value:"); Iterator<Map.Entry<String, String>> it = hMap.entrySet().iterator(); while (it.hasNext()) { Map.Entry<String, String> entry = it.next(); System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue()); } // 第三種:推薦,尤其是容量大時 System.out.println("通過Map.entrySet遍歷key和value"); for (Map.Entry<String, String> entry : hMap.entrySet()) { System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue()); } // 第四種 System.out.println("通過Map.values()遍歷所有的value,但不能遍歷key"); for (String v : hMap.values()) { System.out.println("value= " + v); } }
運行結果:
通過Map.keySet遍歷key和value:
key= 1 and value= value1
key= 2 and value= value2
key= 3 and value= value3
通過Map.entrySet使用iterator遍歷key和value:
key= 1 and value= value1
key= 2 and value= value2
key= 3 and value= value3
通過Map.entrySet遍歷key和value
key= 1 and value= value1
key= 2 and value= value2
key= 3 and value= value3
通過Map.values()遍歷所有的value,但不能遍歷key
value= value1
value= value2
value= value3