zoukankan      html  css  js  c++  java
  • Java遍历Map集合的四种方式

    Map 集合的遍历与 List 和 Set 集合不同。Map 有两组值,因此遍历时可以只遍历值的集合,也可以只遍历键的集合,也可以同时遍历。Map 以及实现 Map 的接口类(如 HashMap、TreeMap、LinkedHashMap、Hashtable 等)都可以用以下几种方式遍历。

    1)在 for 循环中使用 entries 实现 Map 的遍历(最常见和最常用的)。

    public static void main(String[] args) {
        Map<String, String> map = new HashMap<String, String>();
        map.put("Java入门教程", "http://c.biancheng.net/java/");
        map.put("C语言入门教程", "http://c.biancheng.net/c/");
        for (Map.Entry<String, String> entry : map.entrySet()) {
            String mapKey = entry.getKey();
            String mapValue = entry.getValue();
            System.out.println(mapKey + ":" + mapValue);
        }
    }

    2)使用 for-each 循环遍历 key 或者 values,一般适用于只需要 Map 中的 key 或者 value 时使用。性能上比 entrySet 较好。

    public static void main(String[] args) {
        Map<String, String> map = new HashMap<String, String>();
        map.put("Java入门教程", "http://c.biancheng.net/java/");
        map.put("C语言入门教程", "http://c.biancheng.net/c/");
        for (Map.Entry<String, String> entry : map.entrySet()) {
            String mapKey = entry.getKey();
            String mapValue = entry.getValue();
            System.out.println(mapKey + ":" + mapValue);
        }
    }

    3)使用迭代器(Iterator)遍历

    Map<String, String> map = new HashMap<String, String>();
    map.put("Java入门教程", "http://c.biancheng.net/java/");
    map.put("C语言入门教程", "http://c.biancheng.net/c/");
    Iterator<Entry<String, String>> entries = map.entrySet().iterator();
    while (entries.hasNext()) {
        Entry<String, String> entry = entries.next();
        String key = entry.getKey();
        String value = entry.getValue();
        System.out.println(key + ":" + value);
    }

    4)通过键找值遍历,这种方式的效率比较低,因为本身从键取值是耗时的操作。

    for(String key : map.keySet()){
        String value = map.get(key);
        System.out.println(key+":"+value);
    }

    本文来自博客园,作者:三号小玩家,转载请注明原文链接:https://www.cnblogs.com/q1359720840/p/15779985.html

  • 相关阅读:
    HashMap和Hashtable的区别
    装箱以及拆箱
    泛型
    LinkedList和ArrayList异同
    ArrayList的输出方式以及ArrayList的因子增长数
    limit的优化
    mysql五大数据引擎的分别
    ios
    css3(1)
    php
  • 原文地址:https://www.cnblogs.com/q1359720840/p/15779985.html
Copyright © 2011-2022 走看看