zoukankan      html  css  js  c++  java
  • java遍历map的几种方式

    推荐几种遍历map的方式,有键名和键值都遍历的,也有遍历其中之一的,还有while遍历的

    public static void main(String[] args) {
            // 循环遍历Map的4中方法
            Map<Integer, Integer> map = new HashMap<Integer, Integer>();
            map.put(1, 2);
            // 1. entrySet遍历,在键和值都需要时使用(最常用)
            for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
                System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
            }
            // 2. 通过keySet或values来实现遍历,性能略低于第一种方式
            // 遍历map中的键
            for (Integer key : map.keySet()) {
                System.out.println("key = " + key);
            }
            // 遍历map中的值
            for (Integer value : map.values()) {
                System.out.println("key = " + value);
            }
            // 3. 使用Iterator遍历
            Iterator<Map.Entry<Integer, Integer>> it = map.entrySet().iterator();
            while (it.hasNext()) {
                Map.Entry<Integer, Integer> entry = it.next();
                System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
            }
     
            // 4. java8 Lambda
            // java8提供了Lambda表达式支持,语法看起来更简洁,可以同时拿到key和value,
            // 不过,经测试,性能低于entrySet,所以更推荐用entrySet的方式
            map.forEach((key, value) -> {
                System.out.println(key + ":" + value);
            });
            
        }

    如果只是获取key,或者value,推荐使用keySet或者values方式;

    如果同时需要key和value推荐使用entrySet;

    如果需要在遍历过程中删除元素推荐使用Iterator;

    如果需要在遍历过程中增加元素,可以新建一个临时map存放新增的元素,等遍历完毕,再把临时map放到原来的map中。

  • 相关阅读:
    动态规划——E (LIS())最长上升子序列
    动态规划——F 最大矩阵和
    动态规划——I 记忆化搜索
    动态规划——C编辑最短距离
    动态规划——K背包问题
    动态规划——H 最少回文串
    动态规划——G 回文串
    动态规划——J 括号配对问题
    Codeforces4D
    UVa10635
  • 原文地址:https://www.cnblogs.com/phpyangbo/p/15771047.html
Copyright © 2011-2022 走看看