写在前面
HashMap作为常用的数据结构之一,应用场景和使用范围都是非常广泛的。操作集合不外乎就是存取数据。下面我就介绍几种常用的遍历Map的方式。
第一种
使用keySet遍历HashMap
public static void main(String[] args) {
HashMap<String, String> hashMap = new HashMap<>();
hashMap.put("张三", "初级工程师");
hashMap.put("李四", "中级工程师");
hashMap.put("王五", "高级工程师");
Set<String> keySet = hashMap.keySet();
for (String key : keySet) {
String value = hashMap.get(key);
System.out.println("姓名:" + key + ";职位:" + value);
}
}
注意:
使用此方法遍历HashMap时效率是最低的。因为该方法的底层其实是遍历了2次。第一次遍历将Map集合中所有的key拿到,放到一个Set集合中。第二次遍历是通过key获取对应的value。因此当数据量特别大是不考虑使用该方法。
第二种
使用entrySet遍历HashMap
public static void main(String[] args) {
HashMap<String, String> hashMap = new HashMap<>();
hashMap.put("赵六", "测试主管");
hashMap.put("田七", "项目经理");
hashMap.put("亢八", "写BUG的");
Set<Entry<String, String>> entrySet = hashMap.entrySet();
for (Entry<String, String> entry : entrySet) {
System.out.println("姓名:" + entry.getKey() + ";职位:" + entry.getValue());
}
}
注意:
使用该方法遍历HashMap只是遍历了一次就把key和value都放到Entry中了。省去一次遍历的操作,当数据量大时就会明显比使用keySet遍历效率更高。
第三种
其实还有更高效的方法,当使用的是JDK8时,可以采用Map.forEach方法
public static void main(String[] args) {
HashMap<String, String> hashMap = new HashMap<>();
hashMap.put("赵六", "测试主管");
hashMap.put("田七", "项目经理");
hashMap.put("亢八", "写BUG的");
hashMap.forEach(
(key, value) -> System.out.println("姓名:" + key + ";职位:" + value)
);
}
注意:
forEach方法是JDK8中新增的方法。该方法不是线程安全的方法,在多线程并发进行读写操作时会产生ConcurrentModificationException(并发修改异常)。因此使用时需要考虑实际需求。
今天的分享就到这了,如果喜欢记得点赞呦!
你的选择是做或不做,但不做就永远不会有机会。