以下方法适用于任何map实现(HashMap, TreeMap, LinkedHashMap, Hashtable, 等等):
方式一(推荐):
1 // 推荐 2 // 在for-each循环中使用entries来遍历 3 // 注意:for-each循环在Java 5中被引入所以该方法只能应用于java 5或更高的版本中。 4 // 如果你遍历的是一个空的map对象,for-each循环将抛出NullPointerException,因此在遍历前你总是应该检查空引用。 5 private static void testMethod1(Map<Integer, String> map) { 6 7 // 这是最常见的并且在大多数情况下也是最可取的遍历方式。在键值都需要时使用。 8 for (Map.Entry<Integer, String> entry : map.entrySet()) { 9 System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue()); 10 } 11 12 }
方式二:
1 // 方法二 在for-each循环中遍历keys或values。 2 // 如果只需要map中的键或者值,你可以通过keySet或values来实现遍历,而不是用entrySet。 3 // 该方法比entrySet遍历在性能上稍好(快了10%),而且代码更加干净。 4 private static void testMethod2(Map<Integer, String> map) { 5 6 // 遍历map中的键 7 for (Integer key : map.keySet()) { 8 9 System.out.println("Key = " + key); 10 11 } 12 13 // 遍历map中的值 14 for (String value : map.values()) { 15 16 System.out.println("Value = " + value); 17 18 } 19 20 }
方式三:
1 // 方法三使用Iterator遍历 2 // 本方式有两个好处,一是在老版本java中这是惟一遍历map的方式。另一个好处是,你可以在遍历时调用iterator.remove()来删除entries,另两个方法则不能。 3 private static void testMethod3(Map<Integer, String> map) { 4 5 Iterator<Map.Entry<Integer, String>> entries = map.entrySet().iterator(); 6 7 while (entries.hasNext()) { 8 9 Map.Entry<Integer, String> entry = entries.next(); 10 11 System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue()); 12 13 } 14 }
方式四:
1 // 方法四、通过键找值遍历(效率低) 2 // 相当慢且无效率 3 private static void testMethod4(Map<Integer, String> map) { 4 5 for (Integer key : map.keySet()) { 6 7 String value = map.get(key); 8 9 System.out.println("Key = " + key + ", Value = " + value); 10 11 } 12 }
时间: 2024-10-04 04:48:32