zoukankan      html  css  js  c++  java
  • 使用java遍历Map集合的方式

    在java中所有的map都实现了Map接口,因此所有的Map(如HashMap, TreeMap, LinkedHashMap, Hashtable等)都可以用以下的方式去遍历。

    方法一:在for循环中使用entries实现Map的遍历

    @Test
        public void test2(){
            /**
             * 最常见也是大多数情况下用的最多的,一般在键值对都需要使用
             */
            Map<String,String> map = new HashMap<>();
            map.put("姓名", "张三");
            map.put("年龄", "22");
            for(Map.Entry<String, String> entry : map.entrySet()){
                String mapKey = entry.getKey();
                String mapValue = entry.getValue();
                System.out.println(mapKey+" : "+mapValue);
            }
    
        }

    测试结果如下:

    方法二:在for循环中遍历key或者values,一般适用于只需要map中的key或者value时使用,在性能上比使用entrySet较好

    @Test
        public void test2(){
            Map<String,String> map = new HashMap<>();
            map.put("姓名", "张三");
            map.put("年龄", "22");
            //key
            for(String key : map.keySet()){
                System.out.println(key);
            }
            //value
            for(String value : map.values()){
                System.out.println(value);
            }
        }

    测试结果如下:

     

     方法三:通过Iterator遍历

    @Test
        public void test2(){
            Map<String,String> map = new HashMap<>();
            map.put("姓名", "张三");
            map.put("年龄", "22");
            Iterator<Map.Entry<String, String>> entries  = map.entrySet().iterator();
            while(entries.hasNext()){
                Map.Entry<String, String> entry = entries.next();
                String key = entry.getKey();
                String value = entry.getValue();
                System.out.println(key+":"+value);
            }
        }

    测试结果如下:

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

    @Test
        public void test2(){
            Map<String,String> map = new HashMap<>();
            map.put("姓名", "张三");
            map.put("年龄", "22");
            for(String key : map.keySet()){
                String value = map.get(key);
                System.out.println(key+":"+value);
            }
        }

    测试结果如下:

    扩充

  • 相关阅读:
    luogu1196 银河英雄传说 (并查集)
    [BZOJ2243][SDOI2011]染色
    [BZOJ1879] [Sdoi2009]Bill的挑战
    [Noip2003] 侦探推理
    [Noip2005] 篝火晚会
    [JZOJ100047] 【NOIP2017提高A组模拟7.14】基因变异
    [九省联考2018]一双木棋chess
    [Noip2009] 靶形数独
    [Luogu2737] [USACO4.1]麦香牛块Beef McNuggets
    [BZOJ3109] [cqoi2013]新数独
  • 原文地址:https://www.cnblogs.com/liyhbk/p/13553567.html
Copyright © 2011-2022 走看看