前言
最近在看《阿里巴巴Java开发手册(华山版)》,看到了关于Map的遍历方式,手册上写的很详细,我这里用代码再来展示一遍。
代码
public static void main(String[] args) {Map<String, String> hm = new HashMap<String, String>();hm.put("a", "1");hm.put("b", "2");// 1. keySetfor (String key : hm.keySet()) {System.out.println(key + ": " + hm.get(key));}System.out.println("-----------");// 2. entrySetfor (Entry<String, String> entry : hm.entrySet()) {System.out.println(entry.getKey() + ": " + entry.getValue());}System.out.println("-----------");// 3. forEachhm.forEach((key, value) -> {System.out.println(key + ": " + value);});}
运行结果:
说明(来自阿里巴巴Java开发手册):
- keySet 其实是遍历了 2 次,一次是转为 Iterator 对象,另一次是从 hashMap 中取出 key 所对应的 value。
- 而 entrySet 只是遍历了一次就把 key 和 value 都放到了 entry 中,效率更高。
- 如果是 JDK8,使用 Map.forEach 方法。
所以,推荐使用entrySet,如果是JDK8,则推荐forEach。