资讯专栏INFORMATION COLUMN

Java之HashMap迭代删除使用方法小结

mengbo / 2724人阅读

摘要:的迭代删除,和我们常见的,不太一样,不能直接获取对象,提供的删除方法也是单个的,根据进行删除,如果我们有个需求,将中满足某些条件的元素删除掉,要怎么做呢迭代删除迭代删除,在不考虑并发安全的前提下,我们看下可以怎么支持非常不优雅版本我们知道并

map的迭代删除,和我们常见的list,set不太一样,不能直接获取Iteraotr对象,提供的删除方法也是单个的,根据key进行删除,如果我们有个需求,将map中满足某些条件的元素删除掉,要怎么做呢?

I. Map 迭代删除

迭代删除,在不考虑并发安全的前提下,我们看下可以怎么支持

1. 非常不优雅版本

我们知道map并不是继承自Collection接口的,HashMap 也没有提供迭代支持,既然没法直接迭代,那我就老老实的low b版好了

Map map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
map.put("c", 3);
map.put("d", 4);

List removeKey = new ArrayList<>();
for (Map.Entry e: map.entrySet()) {
    if (e.getValue() % 2== 0) {
        removeKey.add(e.getKey());
    }
}
removeKey.forEach(map::remove);

上面的实现怎么样?并没有什么毛病

(为啥不直接在遍历中删除?)

2. 正确姿势版

虽然Map没有迭代,但是它的entrySet有啊,所以我们可以通过它来实现遍历删除

Map map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
map.put("c", 3);
map.put("d", 4);

Iterator> iterator = map.entrySet().iterator();
Map.Entry entry;
while (iterator.hasNext()) {
    entry = iterator.next();
    if (entry.getValue() % 2 == 0) {
        iterator.remove();
    }
}
System.out.println(map);

上面这个可能是我们经常使用的操作姿势了,利用迭代器来操作元素

3. 简洁版

到jdk8之后,针对容器提供了很多简洁的操作方式,迭代删除这方面可以说更加简单了

Map map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
map.put("c", 3);
map.put("d", 4);
map.entrySet().removeIf(entry -> entry.getValue() % 2 == 0);
4. 其他

尽信书则不如,已上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现bug或者有更好的建议,欢迎批评指正,不吝感激

微博地址: 小灰灰Blog

QQ: 一灰灰/3302797840

个人站点 一灰灰Blog: https://liuyueyi.github.io/he...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/74686.html

相关文章

  • java中ConcurrentHashMap使用及在Java 8中的冲突方案

    摘要:中的使用及在中的冲突方案引言简称是在作为的替代选择新引入的,是包的重要成员。为了解决在频繁冲突时性能降低的问题,中使用平衡树来替代链表存储冲突的元素。目前,只有和会在频繁冲突的情况下使用平衡树。 java中ConcurrentHashMap的使用及在Java 8中的冲突方案 1、引言 ConcurrentHashMap(简称CHM)是在Java 1.5作为Hashtable的替代选择新...

    kun_jian 评论0 收藏0
  • Map总结,看这篇就够了

    摘要:继承于,实现了接口。的定义的定义从中,我们可以看出和都实现了接口。指向的的总的大小是迭代器还是枚举类的标志为,表示它是迭代器否则,是枚举类。默认加载因子指定容量大小的构造函数当的实际容量阈值时,阈值总的容量加载因子,就将的容量翻倍。 概要 学完了Map的全部内容,我们再回头开开Map的框架图。showImg(https://segmentfault.com/img/remote/146...

    yzzz 评论0 收藏0
  • Java集合LinkedHashMap源码解析

    摘要:底层基于拉链式的散列结构,并在中引入红黑树优化过长链表的问题。在其之上,通过维护一条双向链表,实现了散列数据结构的有序遍历。 原文地址 LinkedHashMap LinkedHashMap继承自HashMap实现了Map接口。基本实现同HashMap一样,不同之处在于LinkedHashMap保证了迭代的有序性。其内部维护了一个双向链表,解决了 HashMap不能随时保持遍历顺序和插...

    QiShare 评论0 收藏0
  • Map学习一基本操作方法put,get,remove,containsKey

    摘要:返回值存在返回对应的值不存在返回创建集合对象赵丽颖杨颖林志玲杨颖迪丽热巴把指定的键所对应的键值对元素在集合中删除,返回被删除元素的值。 package com.itheima.demo01.Map; import java.util.HashMap;import java.util.Map; /* java.util.Map集合 Map集合的特点: 1.Map集合是一个双列集合...

    TwIStOy 评论0 收藏0
  • Java-集合

    摘要:对象称作迭代器,接口方法能以迭代方式逐个访问集合中各个元素,并可以从中除去适当的元素。一相同点都是迭代器,当需要对集合中元素进行遍历不需要干涉其遍历过程时,这两种迭代器都可以使用。 Collection接口 首先,看一下Collection集合的基本结构:showImg(https://segmentfault.com/img/bVDYWR?w=743&h=380); 1.Collec...

    happen 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<