• HashMap循环遍历方式及其性能对比


    1. Map的四种遍历方式
    下面只是简单介绍各种遍历示例(以HashMap为例),各自优劣会在本文后面进行分析给出结论。
    
    (1) for each map.entrySet()
    
    Map<String, String> map = new HashMap<String, String>();
    for (Entry<String, String> entry : map.entrySet()) {
    entry.getKey();
    entry.getValue();
    }
    
    (2) 显示调用map.entrySet()的集合迭代器
    
    Iterator<Map.Entry<String, String>> iterator = map.entrySet().iterator();
    while (iterator.hasNext()) {
    Map.Entry<String, String> entry = iterator.next();
    entry.getKey();
    entry.getValue();
    }
    
    (3) for each map.keySet(),再调用get获取
    
    Map<String, String> map = new HashMap<String, String>();
    for (String key : map.keySet()) {
    map.get(key);
    }
    
    (4) for each map.entrySet(),用临时变量保存map.entrySet()
    
    Set<Entry<String, String>> entrySet = map.entrySet();
    for (Entry<String, String> entry : entrySet) {
    entry.getKey();
    entry.getValue();
    }
    
    HashMap循环遍历方式性能对比测试代码
    
    PS:如果运行报异常in thread “main” java.lang.OutOfMemoryError: Java heap space,请将main函数里面map size的大小减小。
    
    其中getHashMaps函数会返回不同size的HashMap。
    loopMapCompare函数会分别用上面的遍历方式1-4去遍历每一个map数组(包含不同大小HashMap)中的HashMap。
    print开头函数为输出辅助函数,可忽略。
    
     
    
    测试环境为Windows7 32位系统 3.2G双核CPU 4G内存,Java 7,Eclipse -Xms512m -Xmx512m
    最终测试结果如下:
    
    compare loop performance of HashMap
    -----------------------------------------------------------------------
    map size               | 10,000    | 100,000   | 1,000,000 | 2,000,000
    -----------------------------------------------------------------------
    for each entrySet      | 2 ms      | 6 ms      | 36 ms     | 91 ms    
    -----------------------------------------------------------------------
    for iterator entrySet  | 0 ms      | 4 ms      | 35 ms     | 89 ms    
    -----------------------------------------------------------------------
    for each keySet        | 1 ms      | 6 ms      | 48 ms     | 126 ms    
    -----------------------------------------------------------------------
    for entrySet=entrySet()| 1 ms      | 4 ms      | 35 ms     | 92 ms    
    ----------------------------------------------------------------------
    
    表横向为同一遍历方式不同大小HashMap遍历的时间消耗,纵向为同一HashMap不同遍历方式遍历的时间消耗。
    PS:由于首次遍历HashMap会稍微多耗时一点,for each的结果稍微有点偏差,将测试代码中的几个Type顺序调换会发现,for each entrySet耗时和for iterator entrySet接近。
    
  • 相关阅读:
    利用KubeEdge在A500部署边缘推理任务
    HTTPS详解一
    go语言单元测试:go语言用gomonkey为测试函数或方法打桩
    优秀程序员的十个习惯
    Linux基础
    材料科学笔记
    六级作文:图表类作文
    六级作文:名言警句类论说文
    六级写作:考试介绍 & 万能模板句型 & 练习
    数据分析师能力一:收集信息的能力
  • 原文地址:https://www.cnblogs.com/lhl-shubiao/p/9528783.html
Copyright © 2020-2023  润新知