java Map及Map.Entry详解_xjk201的博客-程序员宝宝_java map.entry

Map是java中的接口,Map.Entry是Map的一个内部接口。

Map提供了一些常用方法,如keySet()、entrySet()等方法。

keySet()方法返回值是Map中key值的集合;entrySet()的返回值也是返回一个Set集合,此集合的类型为Map.Entry。

Map.Entry是Map声明的一个内部接口,此接口为泛型,定义为Entry<K,V>。它表示Map中的一个实体(一个key-value对)。接口中有getKey(),getValue方法。


map不能直接使用迭代器因为map没有像set继承Collection所以得如下方式使用

         

        由以上可以得出,遍历Map的常用方法:

       1.  Map map = new HashMap();

           Irerator iterator = map.entrySet().iterator();

           while(iterator.hasNext()) {

                   Map.Entry entry = iterator.next();

                   Object key = entry.getKey();

                   //

           }

或者

for (Map.Entry<Integer, Integer> entry : map.entrySet()) {}

       2.Map map = new HashMap(); 

           Set  keySet= map.keySet();

           Irerator iterator = keySet.iterator;

           while(iterator.hasNext()) {

                   Object key = iterator.next();

                   Object value = map.get(key);

                   //

           }

 

       另外,还有一种遍历方法是,单纯的遍历value值,Map有一个values方法,返回的是value的Collection集合。通过遍历collection也可以遍历value,如

      Map map = new HashMap();

      Collection c = map.values();

      Iterator iterator = c.iterator();

      while(iterator.hasNext()) {

             Object value = iterator.next(); 

     }


1 import java.util.Collection;
 2 import java.util.HashMap;
 3 import java.util.Iterator;
 4 import java.util.Map;
 5 import java.util.Set;
 6 
 7 public class MapDemo {
 8 
 9     public static void main(String[] args) {
10         Map<Integer,String> map = new HashMap<Integer,String>();
11 
12         
13         map.put(8, "zhaoliu");
14         map.put(9, "zhaoliu");
15         map.put(1, "xiaoqiang");
16         map.put(6, "wangcai");
17         map.put(7, "zhaoliu");
18         map.put(99, "zhaoliu");
19         map.put(87, "xiaoqiang");
20         map.put(42, "wangcai");
21         
22         show1(map);
23         
24         show2(map);
25         
26         showValue(map);
27 
28     }
29 
30     public static void showValue(Map<Integer, String> map) {
31         Collection<String> values = map.values();
32         Iterator<String> it = values.iterator();
33         while (it.hasNext())
34         {
35             System.out.println(it.next());
36         }
37     }
38 
39     public static void show2(Map<Integer, String> map) {
40         //通过Map转成Set就可以迭代
41         //找到了另一种方法。  entrySet
42         //该方法将键和值的映射关系作为对象存储到了Set集合中,而这个映射关系的类型就是Map.Entry类型(结婚证)
43         //就跟Set<Integer> xxxx=new HashSet<>();中的<Integer>跟<Map.Entry<Integer,String>>是一样的
44         Set<Map.Entry<Integer, String>> entrySet = map.entrySet();
45         Iterator<Map.Entry<Integer, String>> it = entrySet.iterator();
46         /*
47          *也可以写成 Iterator<Map.Entry<Integer, String>> it = map.entrySet().iterator();
48          */
49         
50         while(it.hasNext())
51         {
52             Map.Entry<Integer, String> me = it.next();
53             Integer key = me.getKey();
54             String value = me.getValue();
55             System.out.println(key+"::"+value);
56             
57         }
58     }
59 
60     public static void show1(Map<Integer, String> map) {
61         //取出map中的所有元素。
62         //原理:通过keySet方法获取map中所有的键所在的Set集合,在通过Set的迭代器获取到每一个键,
63         //在对每一个键通过map集合的get方法获取其对应的值即可。
64         
65         Iterator<Integer> it = map.keySet().iterator();
66         /*
67          * 相当于  Set<Integer> keySet = map.keySet();
68          *      Iterator<Integer> it = keySet.iterator();
69          *
70          */
71         
72         while (it.hasNext())
73         {
74             Integer key = it.next();
75             String value = map.get(key);
76             System.out.println(key+"="+value);
77         }
78     }
79 
80 }




版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/xjk201/article/details/81056615

智能推荐

【Java】用最少数量的箭引爆气球_请叫我算术嘉的博客-程序员宝宝

package greedy;import java.util.Arrays;import java.util.Comparator;public class findMinArrowShots { public static void main(String[] args){ int[][] p = {{10,16}, {2,8}, {1,6}, {7,12...

Ubuntu设置静态ip(18.04&16.04)_小小程序猿杰瑞的博客-程序员宝宝_ubuntu 设置静态ip

前提条件 一、虚拟机的网络连接方式一定要是NAT方式 二、通过ipaddr或者ifconfig查看自己虚拟机的网卡名称18.04设置静态ip 在终端输入:sudo vim /etc/netplan/01-network-manager-all.yaml然后更改配置如下:network: ethernets: //以太网 ens33: //网卡名称 ...

Laya 3D屏幕截图_cl_001的博客-程序员宝宝

/** * 获取屏幕截图 */public static getScreenTexture():Laya.Texture|Laya.Texture2D{try {let _texture:any = null;//http://ask.layabox.com/question/47246let gl:any = (Laya.WebGLContext as an...

HDU2454 判定简单图_cjoier_zouzhen1211的博客-程序员宝宝_可简单图化的判断方法

2017年3月18日 | ljfcnyali 题目大意: 给出一个图的每个点的度的序列,求能否构成一个简单图;Sample Input26 4 4 3 3 2 24 2 1 1 1Sample Outputyesno题目分析:使用Havel定理,可以轻易地AC。Havel定理: 给定一个非负整数序列{dn}; 若存在一个无向图使得图中各点的度与此序列一一对应; 则称此序列可图化。

【bzoj4327】JSOI2012 玄武密码 AC自动机_weixin_30590285的博客-程序员宝宝

题目描述在美丽的玄武湖畔,鸡鸣寺边,鸡笼山前,有一块富饶而秀美的土地,人们唤作进香河。相传一日,一缕紫气从天而至,只一瞬间便消失在了进香河中。老人们说,这是玄武神灵将天书藏匿在此。很多年后,人们终于在进香河地区发现了带有玄武密码的文字。更加神奇的是,这份带有玄武密码的文字,与玄武湖南岸台城的结构有微妙的关联。于是,漫长的破译工作开始了。经过分析,我们可以用东南西北四个方向来描述台城...

实现Seurat 2 和 Seurat3 在同一个环境下共存_徐洲更hoptop的博客-程序员宝宝

软件升级虽然是一件值得高兴的是,但是代码变化太大却不是一件好消息。比如说Seurat,这个单细胞分析最常用的R包,它的2.x版本和3.x版本的变化就是翻天覆地。为了能够重现别人的代码,你可能需要重装2.3.4版本的Seurat,官方提供了安装脚本source("https://gist.githubusercontent.com/satijalab/beb9b...

随便推点

栈和队列的应用相关习题及详解 ——数据结构_远在远方的风比远方更远的博客-程序员宝宝

习题部分选择题第一题一个问题的递归算法求解和其相对应的非递归算法求解() A. 递归算法通常高效一些 B. 非递归算法通常高效一些 C. 两者相同 D. 无法比较第二题执行()操作时,需要使用队列作为辅助存储空间 A. 查找散列(哈希)表 B. 广度优先搜索图 C. 前序(根)遍历二叉树 D. 深度优先搜索图第三题已知操作符包括‘+’‘-’‘’‘/’‘(’‘)’ 。将

mysql中的rman备份_RMAN备份详解(转载)_鵬鵬鵬鵬的博客-程序员宝宝

网上查到一篇RMAN工具的使用,这篇文档记录写的比较详细,自己目前的工作环境反复使用的几率不高,有些时候就容易忘,特此记录下来。--======================--======================一、数据库备份与RMAN备份的概念1.数据库完全备份:按归档模式分为归档和非归档归档模式打开状态,属于非一致性备份关闭状态,可以分为一致性和非一致性非归档模式打开状态,非一致性...

马士兵高并发编程笔记二之容器读写同步_Rogera7的博客-程序员宝宝

容器读写同步,实时通知实现一个容器,提供两个方法,add,size, 写两个线程,线程1添加10个元素到容器中,线程2实现监控元素的个数,当个数到5个时,线程2给出提示并结束1. volatile方法public class MyContainer2 { //添加volatile,使t2能够得到通知 volatile List lists = new Arra...

泰晤士2021计算机科学排名,2021THE泰晤士高等教育学科排名发布!Top10被英美大学包揽..._weixin_39934613的博客-程序员宝宝

原标题:2021THE泰晤士高等教育学科排名发布!Top10被英美大学包揽出国留学到底是先选专业还是先选学校?为了做出一个最好的选择,我们习惯性地去参考各种权威的大学综合排名以及专业排名。毕竟对于留学生来说,除了世界排名具有很大的参考意义,专业排名也是非常重要的一点,这往往可以左右你的选校定位。作为排名届的四大扛把子之一,泰晤士高等教育(THE)因为对学术的重视,受到了很多申请者的追捧。继 9月2...

CentOS 6.2下更新GCC_weixin_33835690的博客-程序员宝宝

在centos中安装了QT5.1.0,发现无法启动,原因好像是GCC版本问题,所以就更新GCC。1、下载GCC源码:下载网址:http://ftp.gnu.org/gnu/gcc/gcc-4.8.0/ (可以直接访问,我就是在windows下用迅雷下载,拷到虚拟机CentOS中的)wget http://ftp.gnu.org/gnu/gcc/gcc-4.8.0/gcc-4.8.0.t...

C++输入输出流总结_aqns80581的博客-程序员宝宝

转自:http://www.cnblogs.com/chinazhangjie/archive/2010/08/19/1803057.htmlC++ I/OC++支持两种I/O,第一种是从C语言继承来的,一种是由C++定义的面向对象I/O系统。1、int getchar(void);返回一个整数值,也可以指定这个值为char变量,因为这个字符包含于低位字节中(高位...

推荐文章

热门文章

相关标签