java中Map的七种遍历方法

学了一年,到头来连个Map遍历都还要靠百度,真的已经面向了百度了,大概这就是基础没打好吧!且转这儿大家翻翻吧!

首先在java中所有的Map(如HashMap, TreeMap, LinkedHashMap, Hashtable等)都实现了Map接口,因此所有的Map都可以用下面的几种方式去遍历,可根据业务需要进行选择。

方法一、ForEach EntrySet(推荐)

Map <String,String>map = new HashMap<String,String>();
map.put("小王", "男");
map.put("小张", "女");
for(Map.Entry<String, String> entry : map.entrySet()){
    String mapKey = entry.getKey();
    String mapValue = entry.getValue();
    System.out.println(mapKey+":"+mapValue);
}

方法二:ForEach KeySet
在for循环中遍历key或者values,一般适用于只需要map中的key或者value时使用。

Map <String,String>map = new HashMap<String,String>();
map.put("小王", "男");
map.put("小张", "女");
//key
for(String key : map.keySet()){
    System.out.println(key);
    //System.out.println(map.get(key));
}
//value
for(String value : map.values()){
    System.out.println(value);
}

方法三、迭代器 EntrySet(推荐)

Iterator<Entry<String, String>> entries = map.entrySet().iterator();
while(entries.hasNext()){  //通过hasNext来判断是否还有下一个
    Entry<String, String> entry = entries.next();
    String key = entry.getKey();
    String value = entry.getValue();
    //entries.remove(); 迭代器循环中删除数据安全
    System.out.println(key+":"+value);
}

方法四、迭代器 KeySet
通过键找值遍历,这种方式的效率比较低,因为本身从键取值是耗时的操作(跟进去就会发现会遍历两次map)

for(String key : map.keySet()){
    String value = map.get(key);
    System.out.println(key+":"+value);
}

方法五、Lambda

Map<String,String> map=new HashMap<>();
map.put("小王", "男");
map.put("小张", "女");
map.put("小刘", "女");
map.forEach((key,value) -> {
    System.out.println(key);
    System.out.println(value);
});

方法六、Streams API单线程

Map<String,String> map=new HashMap<>();
map.put("小王", "男");
map.put("小张", "女");
map.put("小刘", "女");
map.entrySet().stream().forEach(entry -> {
    System.out.println(entry.getKey()+":"+entry.getValue());
});

方式七、Streams API 多线程

 Map<String,String> map=new HashMap<>();
 map.put("小王", "男");
 map.put("小张", "女");
 map.put("小刘", "女");
 map.entrySet().parallelStream().forEach(entry -> {
     System.out.println(entry.getKey()+":"+entry.getValue());
 });

说明:两种entrySet性能相似,执行速度最快,然后是stream,最后才是keySet。因此日常开发中我们尽量使用entrySet。考虑到安全性我们可以采用迭代器来遍历EntrySet的遍历方式来操作Map集合,这样既高效又安全。
关于HashMap的排序可参考Java 对HashMap 进行排序的几种场景
文章参考:
1、java中Map遍历的四种方式

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

童话ing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值