《java基础》一文让你学会高效的遍历HashMap

写在前面

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(并发修改异常)。因此使用时需要考虑实际需求。


今天的分享就到这了,如果喜欢记得点赞呦!

你的选择是做或不做,但不做就永远不会有机会。

你可能感兴趣的:(java基础)