Map、Map.Entry和增强for循环的详解
2015-09-11 00:22
447 查看
最近在学习集合后,一直对Map和Map.Entry存在些许的疑问和不解,于是查找各种资料,想要看看到底都有哪些不同?Map.Entry在使用到底有什么优势。
比如先看看下面的这种我们常用的遍历(哈哈,应该是我常用的),其中keySet()方法返回的就是该Map中所有key组成的Set组合,然后开始创建遍历Map中所有key的迭代器,之后程序进入循环后,每从Map中取一次key,程序都要返回到Map中取一次关键字所对应的value,如果数据再多点,这样是不是很麻烦呢?
所以,在使用entrySet之后,你就会发现这个会更简单快速的遍历Map, entrySet()方法返回的是Map中包含的key-value所以定的Set集合,其中每个集合元素都是Map.Entry对象。
上面修改后的遍历程序看起来并不比第一个程序看起来简单,但是却省略了每一次对get()的调用(相比第一个哈),同时呢,我们也可以用Map.Entry里面的setValue()方法修改Map里面的值。
其实,增强for循环是不是遍历Map更是简单呢?
这个是每次都要调用get()方法的增强for循环
比如先看看下面的这种我们常用的遍历(哈哈,应该是我常用的),其中keySet()方法返回的就是该Map中所有key组成的Set组合,然后开始创建遍历Map中所有key的迭代器,之后程序进入循环后,每从Map中取一次key,程序都要返回到Map中取一次关键字所对应的value,如果数据再多点,这样是不是很麻烦呢?
Map<Integer,String> map=new HashMap<Integer,String>(); map.put(1, "zhangsan"); map.put(2, "lisi"); map.put(3, "machao"); Set keys=map.keySet(); if(keys!=null){ Iterator it=keys.iterator(); while(it.hasNext()){ Object key=it.next(); Object value=map.get(key); System.out.println(key+","+value); } }
所以,在使用entrySet之后,你就会发现这个会更简单快速的遍历Map, entrySet()方法返回的是Map中包含的key-value所以定的Set集合,其中每个集合元素都是Map.Entry对象。
Set entrys=map.entrySet(); if(entrys!=null){ Iterator it=entrys.iterator(); while(it.hasNext()){ Map.Entry<Integer, String> entry=(Entry<Integer, String>) it.next(); Object key=entry.getKey(); Object value=entry.getValue(); System.out.println(key+":"+value); } }
上面修改后的遍历程序看起来并不比第一个程序看起来简单,但是却省略了每一次对get()的调用(相比第一个哈),同时呢,我们也可以用Map.Entry里面的setValue()方法修改Map里面的值。
其实,增强for循环是不是遍历Map更是简单呢?
for(Map.Entry<Integer, String> e:map.entrySet()){ Integer key=e.getKey(); String value=e.getValue(); System.out.println(key+":"+value); }
这个是每次都要调用get()方法的增强for循环
for(Integer key:map.keySet()){ String value=map.get(key); System.out.println(key+":"+value); }
相关文章推荐
- LRU的cache的实现
- 说下 winOS / IOS / android /Linux 视频、音频 编码解码问题
- igrimaceV8.0.0 IG 一键新机 陌陌 Uber优步打针 平安易贷 滴滴 一号专车 饿了么 ios8 V8 ZTN(插件安装方式)
- 国内外免费PHP开源建站程序
- HDU_1533_Going Home(最小费用流模板)
- C/S架构和B/S架构的概念和区别
- CodeForces 11B - Jumping Jack
- MessageBox
- centos6下mysql的主从复制的配置
- hdu(5375)——Gray codet
- c#验证串口可用性
- HDU 5221 Occupation dfs序版树链剖分
- 排序算法
- js基本概念注意点—操作符
- 9.10Axure动态设置
- CodeForces 12A - Super Agent
- java tips
- Webview--如何让加载进来的页面自适应手机屏幕分辨率居中
- 第五篇:OC中特有的 点语法 对成员变量赋值与取值
- VC++平台上的内存对齐操作