HashMap遍历的四种方法

HashMap遍历的四种方法方法 1 使用 For Each 迭代 entries 这是最常见的方法 并在大多数情况下更可取的 当你在循环中需要使用 Map 的键和值时 就可以使用这个方法 Mapmap newHashMap for Map Entryentry map entrySet System out println key entry getKey valu

方法1:使用For-Each迭代entries

这是最常见的方法,并在大多数情况下更可取的。当你在循环中需要使用Map的键和值时,就可以使用这个方法


Map 
  
    map = new HashMap 
   
     (); for(Map.Entry 
    
      entry : map.entrySet()){ System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue()) } 
     
    
  

注意:For-Each循环是Java5新引入的,所以只能在Java5以上的版本中使用。如果你遍历的map是null的话,For-Each循环会抛出NullPointerException异常,所以在遍历之前你应该判断是否为空引用。

方法2 使用For-Each迭代keys和values

如果你只需要用到map的keys或values时,你可以遍历KeySet或者values代替entrySet

Map 
  
    map = new HashMap 
   
     (); //iterating over keys only for (Integer key : map.keySet()) { System.out.println("Key = " + key); } //iterating over values only for (Integer value : map.values()) { System.out.println("Value = " + value); } 
    
  

这个方法比entrySet迭代具有轻微的性能优势(大约快10%)并且代码更简洁

方法3 使用Iterator迭代

使用泛型

Map 
  
    map = new HashMap 
   
     (); Iterator 
    
      > entries = map.entrySet().iterator(); while (entries.hasNext()) { Map.Entry 
     
       entry = entries.next(); System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue()); } 
      
     
    
  

不使用泛型

Map map = new HashMap(); Iterator entries = map.entrySet().iterator(); while (entries.hasNext()) { Map.Entry entry = (Map.Entry) entries.next(); Integer key = (Integer)entry.getKey(); Integer value = (Integer)entry.getValue(); System.out.println("Key = " + key + ", Value = " + value); } 

你可以使用同样的技术迭代keyset或者values

这个似乎有点多余但它具有自己的优势。首先,它是遍历老java版本map的唯一方法。另外一个重要的特性是可以让你在迭代的时候从map中删除entries的(通过调用iterator.remover())唯一方法.如果你试图在For-Each迭代的时候删除entries,你将会得到unpredictable resultes 异常。

从性能方法看,这个方法等价于使用For-Each迭代

方法4 迭代keys并搜索values(低效的)

Map 
  
    map = new HashMap 
   
     (); for (Integer key : map.keySet()) { Integer value = map.get(key); System.out.println("Key = " + key + ", Value = " + value); } 
    
  

这个方法看上去比方法#1更简洁,但是实际上它更慢更低效,通过key得到value值更耗时(这个方法在所有实现map接口的map中比方法#1慢20%-200%)。如果你安装了FindBugs,它将检测并警告你这是一个低效的迭代。这个方法应该避免

代码演示:

package com.gcc.interview; import java.util.HashMap; import java.util.Iterator; import java.util.Map; / * HashMap 不同遍历方法比较 * @author gcc * * 2018年1月22日 */ public class TestHashMap { public static void main(String[] args) { Map       map =new HashMap         (); map.put(1, "xiao"); map.put(2, "chao"); map.put(3, "shang"); map.put(4, "xue"); //方法一 for(Map.Entry           entry : map.entrySet()) { System.out.println("方法一:key ="+entry.getKey()+"---value="+entry.getValue()); } //方法二 for(Integer key:map.keySet()) { System.out.println("方法二:key = "+key); } for(String value:map.values()) { System.out.println("方法二:value = "+value); } //方法三 Iterator             > entries = map.entrySet().iterator(); while(entries.hasNext()) { Map.Entry               entry = entries.next(); System.out.println("方法三:key = "+entry.getKey()+"--value="+entry.getValue()); } //方法四 for(Integer key:map.keySet()) { String value = map.get(key); System.out.println("方法四:Key = " + key + ", Value = " + value); } } }                         
可以根据不同需求选择不同遍历方法,但一般选择第一种方法就可以。

作者:scgyus

转载请注明出处:http://blog.csdn.net/scgyus/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/223742.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午1:31
下一篇 2026年3月17日 下午1:31


相关推荐

  • 初识网络原理

    初识网络原理目录 1 网络互连 1 1 局域网 1 2 广域网 2 网络通信基础 2 1IP 地址 2 2 端口号 3 认识协议 3 1 五元组 3 2 协议分层 3 3OSI7 层模型 3 4TCP IP5 层 或 5 层 模型 3 5 网络设备所在分层 4 封装和分用 1 网络互连 什么是网络互连 将多台计算机连接在一起 完成数据共享 数据共享本质是网络数据传输 即计算机之间通过网络来传输数据 也称为网络通信 网络互连的分类 根据网络互连的规模的不同 我们将其分为局域网和广域网

    2026年3月26日
    3
  • networkx画有向图和无向图

    networkx画有向图和无向图代码和结果如下所示 frommatplotl font managerimpor pyplotasplti FontProperti fname r C Windows Fonts STXINGKA TTF size 20 fname 指定字体文件选简体显示中文 定义图的节点和边 nodes 0 1 2 3

    2026年3月18日
    1
  • Flex 布局全解

    Flex 布局全解一 Flex 布局是什么 Flex 是 FlexibleBox 的缩写 意为 弹性布局 用来为盒状模型提供最大的灵活性 任何一个容器都可以指定为 Flex 布局 box display flex 行内元素也可以使用 Flex 布局 box display inline flex Webkit 内核的浏览器 必须加上 webkit 前缀 box display webkit

    2026年3月18日
    3
  • freemarker 教程_freemarker自定义标签

    freemarker 教程_freemarker自定义标签FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或HTTP。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,JSP或Java等。页面的静态化有的较多中的注释都是以#号表示的第一个项目结构代码的实现[java…

    2022年10月6日
    7
  • Latex符号表

    Latex符号表参考资料 来次大学

    2026年3月19日
    3
  • Android布局详解之二:LinearLayout

    Android布局详解之二:LinearLayout原创文章,如有转载,请注明出处:http://blog.csdn.net/yihui823/article/details/6702312线性布局。这个布局简单的说,就是所有控件都依次排序,谁也不会覆盖谁。线性布局需要定义一个方向,横向(android:orientation

    2022年5月5日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号