• Java集合的遍历方式


    Map的遍历

    1.通过map.entrySet遍历Key和Value

    Map<Integer,Integer> map = new HashMap<>();
            map.put(1, 10);
            map.put(2, 8);
    for(Map.Entry<Integer, Integer> entry : map.entrySet()) {
        System.out.println(entry.getKey() + " ---- " + entry.getValue() );
    }

    如果你遍历的Map是一个空的对象(null),for-each循环将会抛出java.lang.NullPointerException异常

    2.通过map.keySet()来遍历key,通过map.values()来遍历Value,适用于只需要map中的Key或者Value的情况

    Map<Integer,Integer> map = new HashMap<>();
            map.put(1, 10);
            map.put(2, 8);
            for (Integer i : map.keySet()) {
                System.out.println(i);
            }
            
            for ( Integer i : map.values()) {
                System.out.println(i);
            }

    3.通过Iterator遍历Map

    //使用泛型
    Map<Integer,Integer> map = new HashMap<>(); map.put(1, 10); map.put(2, 8); Iterator<Map.Entry<Integer, Integer>> iterator = map.entrySet().iterator(); while (iterator.hasNext()) { Map.Entry<Integer, Integer> temp = iterator.next(); System.out.println(temp.getKey() + " ----- " + temp.getValue()); }

    //不使用泛型
    Map<Integer,Integer> map = new HashMap<>();
            map.put(1, 10);
            map.put(2, 8);
            Iterator iterator = map.entrySet().iterator();
            while (iterator.hasNext()) {
                Map.Entry entry = (Map.Entry) iterator.next();
                Integer key = (Integer) entry.getKey();
                Integer value = (Integer) entry.getValue();
                System.out.println(key + " ----- " + value);
            }

    4. 通过key找value(效率低)

    Map<Integer,Integer> map = new HashMap<>();
            map.put(1, 10);
            map.put(2, 8);
            for ( Integer key : map.keySet()) {
                Integer value = map.get(key);
                System.out.println(key + " ----- " + value);
            }

     List的遍历

    1.方式一

    List<Integer> list = new ArrayList<>();
            list.add(1);
            list.add(2);
            for ( Integer i : list) {
                System.out.println(i);
            }

    2.方式二

    List<Integer> list = new ArrayList<>();
            list.add(1);
            list.add(2);
            Iterator iterator = list.iterator();
            while(iterator.hasNext()) {
                System.out.println(iterator.next());
            }

    3.方式三

    List<Integer> list = new ArrayList<>();
            list.add(1);
            list.add(2);
            for ( int i = 0 ; i < list.size() ; i++ ) {
                System.out.println(list.get(i));
            }

    转载于:https://www.cnblogs.com/fangpengchengbupter/p/7339858.html

  • 相关阅读:
    tomcat拒绝接收请求记录
    js阻止事件冒泡
    BZOJ 5381 or & Codeforces 623E Transforming Sequence DP+NTT
    BZOJ5384 有趣的字符串题 回文树
    Codeforces 932G Palindrome Partition 回文树+DP
    LOJ2542 随机游走 Min-Max容斥+树上期望DP
    LOJ6070 基因 分块+回文自动机
    BZOJ3682 Phorni 后缀平衡树
    Codeforces 994F Compute Power 二分+DP
    BZOJ2759一个动态树好题 LCT
  • 原文地址:https://www.cnblogs.com/twodog/p/12139672.html
Copyright © 2020-2023  润新知