​今天不举例子了,问一句你开心吗?不开心也要记得把开心的事情放到快乐源泉小瓶子里,偶尔拿出来一一遍历看看。

Map在我们Java程序员高频使用的一种数据结构,Map的遍历方式也有很多种,那那种方式比较高效呢,今天就带大家一起验证下。

先说一下阿里巴巴Java开发手册的建议:

【推荐】使用entrySet遍历Map类集合K/V,而不是用keySet方式遍历。

说明:keySet其实遍历了2次,一次是转换为Iterator对象,另一次是从hashMap种取出key对应的value。如果是JDK8,使用Map.forEash方法。

1:通过for和map.entrySet()方式遍历。

// Map初始化
private static Map<String,Integer> initMap(int count){
AlternativeJdkIdGenerator alternativeJdkIdGenerator = new AlternativeJdkIdGenerator();
Map<String,Integer> map = new HashMap<>();
for (int i = 0; i < count; i++) {
map.put(alternativeJdkIdGenerator.generateId().toString(),i) ;
}
return map ;
}
int count = 1000000;
Map<String,Integer> map =initMap(count) ;
// 为了计算平均值,分别循环三次进行遍历
for (int i = 0; i < 3; i++) {
Instant start;
Instant end;
start = Instant.now();
for (Map.Entry<String, Integer> entry : map.entrySet()) {
// 一般遍历map就是获取key和value
String result="key为:"+entry.getKey()+",value为:"+entry.getValue();
}
end = Instant.now();
System.out.println("遍历循环" + count + "次耗时:" + Duration.between(start, end).toMillis() + "ms");
}

运行三次的结果如下:(平均值:368.33ms)

​2、通过 for, Iterator 和 map.entrySet() 来遍历

  int count = 1000000;
Map<String,Integer> map =initMap(count) ;
for (int i = 0; i < 3; i++) {
Instant start;
Instant end;
start = Instant.now();
for (Iterator<Map.Entry<String,Integer>> entries = map.entrySet().iterator(); entries.hasNext(); ) {
Map.Entry<String,Integer> entry = entries.next();
String result ="key为:"+entry.getKey()+",value为:"+entry.getValue();
}
end = Instant.now();
System.out.println("遍历循环" + count + "次耗时:" + Duration.between(start, end).toMillis() + "ms");
}

​运行三次的结果如下:(平均值:339.66ms)

​3、通过 for 和 map.keySet() 来遍历

 int count = 1000000;
Map<String,Integer> map =initMap(count) ;
for (int i = 0; i < 3; i++) {
Instant start;
Instant end;
start = Instant.now();
for (String key : map.keySet()) {
String result ="key为:"+key+",value为:"+map.get(key);
}
end = Instant.now();
System.out.println("遍历循环" + count + "次耗时:" + Duration.between(start, end).toMillis() + "ms");
}

运行三次的结果如下:(平均值:379.66ms)

​4、通过 for,Iterator 和 map.keySet() 来遍历

  int count = 1000000;
Map<String,Integer> map =initMap(count) ;
for (int i = 0; i < 3; i++) {
Instant start;
Instant end;
start = Instant.now();
for (Iterator<String> key = map.keySet().iterator(); key.hasNext(); ) {
String k = key.next();
String result ="key为:"+k+",value为:"+map.get(k);
}
end = Instant.now();
System.out.println("遍历循环" + count + "次耗时:" + Duration.between(start, end).toMillis() + "ms");
}

运行三次的结果如下:(平均值330.33ms)

5、通过 map.forEach() 来遍历

int count = 1000000;
Map<String,Integer> map =initMap(count) ;
for (int i = 0; i < 3; i++) {
Instant start;
Instant end;
start = Instant.now();
map.forEach((key, value) -> {
String result ="key为:"+key+",value为:"+map.get(value);
});
end = Instant.now();
System.out.println("遍历循环" + count + "次耗时:" + Duration.between(start, end).toMillis() + "ms");
}

​运行三次的结果如下:(平均值506.33ms)

​经过上面的验证(在大批量数据的时候,数据量小的时候没测试,感觉数据量小的化耗时太小更不好比较)最好不要用map.forEach()来遍历Map。在普通的遍历方法中 entrySet() 的方法要比使用 keySet() 的方法好。【PS虽然keySet() 的平均值有时候比较小,但它的波动性比较大,所以还是考虑阿里巴巴Java开发手册的建议使用entrySet()遍历Map】。

看过 HashMap 源码的同学应该会发现,这个遍历方式【entrySet(】在源码中也有使用,如下图所示。

 

​Spring的源码也有很多的Map,大神们遍历的方式也都基本使用entrySet()遍历如下:

所以开发中也建议使用entrySet()来遍历Map。

阿里巴巴建议这样遍历Map,今天就用几种方式做个比较一下看那种最好用的更多相关文章

  1. 遍历HashMap常用的的三种方式

    遍历HashMap常用的的三种方式 HashMap是我们使用非常多的集合之一,下面就来介绍几种常用的HashMap的遍历方式. 1.首先定义一个新的HashMap,并往里面添加一些数据. HashMa ...

  2. 遍历Map和List的几种方法和性能比较

    public static void main(String[] args) { Map<String, String> map = new HashMap<String, Stri ...

  3. 遍历Map集合:java.util.Map.Entry、KeySet两种方式

    遍历Map集合的两种方式: 1.用KeySet Map.keySet(),返回一个存放所有key的set集合,通过遍历集合,根据key值取出所有的value值. Map<String,Strin ...

  4. 遍历 Dictionary,你会几种方式?

    一:背景 1. 讲故事 昨天在 StackOverflow 上看到一个很有趣的问题,说: 你会几种遍历字典的方式,然后跟帖就是各种奇葩的回答,挺有意思,马上就要国庆了,娱乐娱乐吧,说说这种挺无聊的问题 ...

  5. Java遍历Map对象的四种方式

    关于java中遍历map具体哪四种方式,请看下文详解吧. 方式一 :这是最常见的并且在大多数情况下也是最可取的遍历方式.在键值都需要时使用. Map<Integer, Integer> m ...

  6. 【转】Java遍历Map对象的四种方式

    关于java中遍历map具体哪四种方式,请看下文详解吧. 方式一 这是最常见的并且在大多数情况下也是最可取的遍历方式.在键值都需要时使用. Map<Integer, Integer> ma ...

  7. 键盘录入一个文件夹路径,统计该文件夹(包含子文件夹)中每种类型的文件及个数,注意:用文件类型(后缀名,不包含.(点),如:"java","txt")作为key, 用个数作为value,放入到map集合中,遍历map集合

    package cn.it.zuoye5; import java.io.File;import java.util.HashMap;import java.util.Iterator;import ...

  8. (1)集合 ---遍历map集合

    Map接口     实现Map接口的类用来存储键(key)-值(value) 对.Map 接口的实现类有HashMap和TreeMap等.Map类中存储的键-值对通过键来标识,所以键值不能重复. Ha ...

  9. Java中遍历Map的四种方式

    Demo如下 Map<String, String> map = new HashMap<>(); map.put("key1","data1&q ...

  10. Java Array数组 遍历 四种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.Arrays; /** * @Author Miracle Luna * @Date ...

随机推荐

  1. 从零开始:在树莓派上安装OpenEuler

    树莓派(Raspberry Pi)是一款基于ARM架构的小型电脑,它的便携性和低功耗性能使它成为制作物联网设备或运行嵌入式系统的理想选择.在这篇博客中,我们将介绍如何在树莓派上安装OpenEuler操 ...

  2. DataRow[]数组转换为DataTable

    DataRow[] drData=DataTable.Select("....."); DataTable dtNew=drData.CopyToDataTable(); 注:Da ...

  3. 新安装的eclipse没有新建java project----解决方法:安装插件

    问题描述:最近新安装的一个eclipse版本,建立新工程的时候发现没有java project选项,如下: 百度了一些资料:https://blog.csdn.net/sinat_41752599/a ...

  4. element ui 点击选中表头并改变表头样式

    前言: header-cell-style 表头单元格的 style 的回调方法,也可以使用一个固定的 Object 为所有表头单元格设置一样的 Style. Function({row, colum ...

  5. jetson TX2 + opencv3.4 + python3 + 双目 +人脸检测

    淘宝看到一款很便宜的双目,150元,就买了.想着用它学习一下opencv,好换个工作.当然,也想着能否用它做一些好玩的,比如三维重建之类高大上的东西.先用便宜的入个门,等以后眼界高了再看是不是买那些更 ...

  6. 解决git仓库项目 添加到github非空仓库冲突问题 error: failed to push some refs to 'https://github.com/Qtoken/......'

    error: failed to push some refs to 'https://github.com/Qtoken/......' 1. 问题描述:执行命令:git push origin m ...

  7. Docker 环境规划 (Docker安装)

    一.环境规划 支持Java.dotNet.Vue项目构建 二.切换系统镜像源   1.备份      mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.rep ...

  8. How to Install VMware Tools on CentOS 6.5

    yum install perl gcc make kernel-headers kernel-devel -y [root@centos6 vmware-tools-distrib]# ./vmwa ...

  9. 5-CSRF漏洞

    1.CSRF介绍 Csrf漏洞也被称为One Click Attack或者Session Riding,通常缩写为CSRF或者XSRF,是一种对网站的恶意利用.尽管听起来像xss漏洞,但是它与xss漏 ...

  10. 用javassist和CGLIB 解决JDK动态代理的缺陷

     用 javassist 解决 JDK 动态代理的缺陷 JDK动态代理的缺陷 要求目标类必须实现接口,否则产生不了代理.有些场景下,目标类也要产生代理类但是木有实现接口,这个时间 Java 中有两个常 ...