• 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接近。
    
  • 相关阅读:
    sqlmap从入门到精通-第四章-4-6 MySQL数据库导入与导出攻略
    Python文章索引(持续更新~)
    如何用 Python 绘制玫瑰图等常见疫情图
    《民国奇探》的弹幕有点逗比,用 Python 爬下来看看
    发现了合自己胃口的公众号,但文章太多翻来翻去真麻烦,还好我学了 Python
    潘粤明的《龙岭迷窟》到底怎么样?我用 Python 得出了一些结论!
    Python 分析电影《南方车站的聚会》
    使用 Scrapy 爬取去哪儿网景区信息
    Python 爬虫(二):Requests 库
    Python 爬虫(一):爬虫伪装
  • 原文地址:https://www.cnblogs.com/lhl-shubiao/p/9528783.html
Copyright © 2020-2023  润新知