Map集合遍历的四种方式理解和简单使用

~Map集合是键值对形式存储值的,所以遍历Map集合无非就是获取键和值,根据实际需求,进行获取键和值

1:无非就是通过map.keySet()获取到值,然后根据键获取到值

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

2:通过Map.Entry(String,String) 获取,然后使用entry.getKey()获取到键,通过entry.getValue()获取到值

  for(Map.Entry<String, String> entry : map.entrySet()){             System.out.println("键 key :"+entry.getKey()+" 值value :"+entry.getValue());         }

3:其中通过Iterator也是为了最终获得entry,所以理解其用法,可以很好的使用和掌握

 1 package com.bie;
 2 
 3 import java.util.HashMap;
 4 import java.util.Iterator;
 5 import java.util.Map;
 6 
 7 /** 
 8 * @author BieHongLi 
 9 * @version 创建时间:2017年2月25日 下午8:58:54 
10 * 
11 */
12 public class MapTest01 {
13 
14     public static void main(String[] args) {
15         Map<String, String> map=new HashMap<String, String>();
16         map.put("张三1", "男");
17         map.put("张三2", "男");
18         map.put("张三3", "男");
19         map.put("张三4", "男");
20         map.put("张三5", "男");
21         
22         //第一种遍历map的方法,通过加强for循环map.keySet(),然后通过键key获取到value值
23         for(String s:map.keySet()){
24             System.out.println("key : "+s+" value : "+map.get(s));
25         }
26         System.out.println("====================================");
27         
28         //第二种只遍历键或者值,通过加强for循环
29         for(String s1:map.keySet()){//遍历map的键
30             System.out.println("键key :"+s1);
31         }
32         for(String s2:map.values()){//遍历map的值
33             System.out.println("值value :"+s2);
34         }
35         System.out.println("====================================");    
36         
37         //第三种方式Map.Entry<String, String>的加强for循环遍历输出键key和值value
38         for(Map.Entry<String, String> entry : map.entrySet()){
39             System.out.println("键 key :"+entry.getKey()+" 值value :"+entry.getValue());
40         }
41         System.out.println("====================================");
42         
43         //第四种Iterator遍历获取,然后获取到Map.Entry<String, String>,再得到getKey()和getValue()
44         Iterator<Map.Entry<String, String>> it=map.entrySet().iterator();
45         while(it.hasNext()){
46             Map.Entry<String, String> entry=it.next();
47             System.out.println("键key :"+entry.getKey()+" value :"+entry.getValue());
48         }
49         System.out.println("====================================");
50         
51     }
52     
53     
54 }

4:Map的一些常用的知识点,和取值的变形形式,都需要掌握和了解

 1 package com.bie;
 2 
 3 import java.util.Collection;
 4 import java.util.HashMap;
 5 import java.util.Map;
 6 import java.util.Set;
 7 
 8 /** 
 9 * @author BieHongLi 
10 * @version 创建时间:2017年2月26日 上午11:29:59 
11 * 
12 */
13 public class MapTest02 {
14 
15     public static void main(String[] args) {
16         //1:key,value都是object类型的
17         //2:key必须是唯一的,不唯一,那么后面的value会把前面的value覆盖
18         //3:对于HashMap,key可以为空
19         //4:value可以为空,也可以为空
20         //5:HashTable的key和value不能为空
21         //6:properties的key和value必须为String类型的
22         Map<String , String> map=new HashMap<>();
23         map.put("null", "this is null 1");
24         map.put("null", "this is null 2");
25         System.out.println(map.size());
26         System.out.println(map.get(null));
27         
28         System.out.println("=============================");
29         //循环显示map类型的key以及对应的value
30         //三个集合,key的集合,value的集合,键值对的集合
31         Set<String> keys=map.keySet();
32         for(String s:keys){
33             System.out.println(s);
34         }
35         System.out.println("=============================");
36         Collection<String> values=map.values();//值的集合
37         System.out.println(values);
38         System.out.println("=============================");
39         Set<Map.Entry<String, String>> entrys=map.entrySet();//键值对的集合
40         for(Map.Entry<String, String> entry:entrys){
41             System.out.println(entry.getKey()+" "+entry.getValue());
42         }
43         
44     }
45 }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏机器学习从入门到成神

Java之使用增强for循环和迭代器遍历

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_35512245/articl...

641
来自专栏开发之途

Java集合框架源码解析之HashSet

1054
来自专栏desperate633

LintCode 二叉树的层次遍历 II题目代码

给出一棵二叉树,返回其节点值从底向上的层次序遍历(按从叶节点所在层到根节点所在的层遍历,然后逐层从左往右遍历)

784
来自专栏LinkedBear的个人空间

唠唠SE的集合-02——Iterator迭代器

迭代时如果没有先执行next()则会抛出IllegalStateException,这就意味着必须要先检查是否还有下一个可以被迭代的元素,才能往外取。

853
来自专栏一枝花算不算浪漫

Java中常见数据结构List之LinkedList

2725
来自专栏LinkedBear的个人空间

唠唠SE的集合-10——Collections工具类

411
来自专栏IT笔记

ArrayList和LinkedList的区别

首先来看ArrayList和LinkedList的集成类和接口的区别。 public class ArrayList<E> extends AbstractLi...

3108
来自专栏Danny的专栏

Java基础——Set接口

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

832
来自专栏Android开发指南

10.TreeSet、比较器

34810
来自专栏余林丰

迭代器模式

今天要说的迭代器模式,实际上就是Java已经为我们实现好了,那就是Java的Iterator类。包括很多编程语言也有自己的迭代器类,但同时它也是一个设计模式,所...

1647

扫码关注云+社区