搜索
您的当前位置:首页正文

Map遍历的几种方式

来源:步旅网

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

public class ForMapDemo {
    public static void main(String[] args) {
        Map<String,String>map=new HashMap<>();

        map.put("username", "qq");
        map.put("passWord", "123");
        map.put("userID", "1");
        map.put("email", "qq@qq.com");
        /**
         * 在for循环中使用entries实现Map的遍历:
         */
        System.out.println("在for循环中使用entry实现Map的遍历");
        for(Map.Entry entry:map.entrySet()){
            System.out.println(entry.getKey()+"--->"+entry.getValue());
        }
        /**
         * 在for循环中遍历key或者values,一般适用于只需要map中的key或者value时使用,
         * 在性能上比使用entrySet较好;
         */
        System.out.println("在for循环中遍历key或者values,一般适用于只需要map中的key或者value时使用,");
        for (String key:map.keySet()){
            System.out.println(key);
        }
        for (String value:map.values()){
            System.out.println(value);
        }
        /**
         * 通过Iterator遍历;
         */
        System.out.println("通过Iterator遍历");
        Iterator<Map.Entry<String, String>> iterator = map.entrySet().iterator();
        while (iterator.hasNext()){
            Map.Entry<String, String> entry = iterator.next();
            System.out.println(entry.getKey()+"--->"+entry.getValue());
        }
        /**
         * 通过键找值遍历,这种方式的效率比较低,因为本身从键取值是耗时的操作;
         */
        System.out.println("通过键找值遍历,这种方式的效率比较低,因为本身从键取值是耗时的操作");
        for (String key:map.keySet()){
            System.out.println(key+"--->"+map.get(key));
        }
    }
}

运行结果:
在for循环中使用entries实现Map的遍历
passWord--->123
userID--->1
email--->qq@qq.com
username--->qq

在for循环中遍历key或者values,一般适用于只需要map中的key或者value时使用,
passWord
userID
email
username
123
1
qq@qq.com
qq

通过Iterator遍历
passWord--->123
userID--->1
email--->qq@qq.com
username--->qq

通过键找值遍历,这种方式的效率比较低,因为本身从键取值是耗时的操作
passWord--->123
userID--->1
email--->qq@qq.com
username--->qq

参考:https://www.cnblogs.com/damoblog/p/9124937.html
https://www.php.cn/java/guide/464203.html

因篇幅问题不能全部显示,请点此查看更多更全内容

Top