这里有新鲜出炉的Java函数式编程,程序狗速度看过来!
java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由Sun Microsystems公司于1995年5月推出的Java程序设计语言和Java平台(即JavaEE(j2ee), JavaME(j2me), JavaSE(j2se))的总称。
相信大家都知道在Java中Map的使用非常频繁,我们经常会需要对Map进行遍历和读取,那么下面这篇文章将展示两种遍历的方法以及简要分析。有需要的可以参考借鉴,下面来一起看看吧。
前言
在java中遍历Map有不少的方法。这篇文章我们就来看一下Java读取Map的两种方法以及这两种方法的对比。
一、 遍历Map方法A
- Map map = new HashMap();
- Iterator iter = map.entrySet().iterator();
- while (iter.hasNext()) {
- Map.Entry entry = (Map.Entry) iter.next();
- Object key = entry.getKey();
- Object val = entry.getValue();
- }
二、遍历Map方法B
- Map map = new HashMap();
- Iterator iter = map.keySet().iterator();
- while (iter.hasNext()) {
- Object key = iter.next();
- Object val = map.get(key);
- }
三、分析遍历方法
方法A: 在遍历中一次读取
,然后直接获取的值。
- Map.Entry
方法B: 基于keySet则是,先遍历,然后再从Map中读取信息。
四、性能测试
- import java.util.HashMap;
- import java.util.Iterator;
- import java.util.Map;
- import org.junit.BeforeClass;
- import org.junit.Test;
- public class MapLoopA {
- private static Map < Integer,
- String > infos = new HashMap < Integer,
- String > ();
- @BeforeClass public static void setUp() {
- for (int i = 0; i < 1000000; i++) {
- infos.put(i, "test information" + i);
- }
- System.out.println("setUp is done.");
- }
- @Test public void testMapLoopA() {
- Iterator < Map.Entry < Integer,
- String >> iterator = infos.entrySet().iterator();
- long startTime = System.currentTimeMillis();
- while (iterator.hasNext()) {
- Map.Entry < Integer,
- String > entry = iterator.next();
- int key = entry.getKey();
- String val = entry.getValue();
- }
- System.out.println("A solution takes in looping Map with 1000000 entries:" + (System.currentTimeMillis() - startTime) + " milli seconds");
- }
- @Test public void testMapLoopB() {
- Iterator < Integer > iterator = infos.keySet().iterator();
- long startTime = System.currentTimeMillis();
- while (iterator.hasNext()) {
- int key = iterator.next();
- String val = infos.get(key);
- }
- System.out.println("B solution takes in looping Map with 1000000 entries:" + (System.currentTimeMillis() - startTime) + " milli seconds");
- }
- }
测试结果:
由此可见,在Map中存放1000000个数据,并在此数据集合中,进行遍历。效率上差异将近1倍的性能差异。
五、总结
好了,以上就是这篇文章的全部内容了,可以看车方法A的效率总体要高一些。一般推荐大家使用方法A。希望本文的内容对大家的学习或者工作能带来一定的帮助。
来源: http://www.phperz.com/article/17/1127/359383.html