zoukankan      html  css  js  c++  java
  • 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接近。
    
  • 相关阅读:
    async/await使用深入详解
    尴尬的事情又发生Newtonsoft.Json vs Protobuf.net
    在dotnet core下去中心化访问HTTP服务集群
    条件随机场CRF(一)从随机场到线性链条件随机场
    用hmmlearn学习隐马尔科夫模型HMM
    隐马尔科夫模型HMM(四)维特比算法解码隐藏状态序列
    隐马尔科夫模型HMM(三)鲍姆-韦尔奇算法求解HMM参数
    隐马尔科夫模型HMM(二)前向后向算法评估观察序列概率
    隐马尔科夫模型HMM(一)HMM模型
    EM算法原理总结
  • 原文地址:https://www.cnblogs.com/lhl-shubiao/p/9528783.html
Copyright © 2011-2022 走看看