欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java基础教程之HashMap迭代删除使用方法

程序员文章站 2024-02-07 14:42:28
前言 map的迭代删除,和我们常见的list,set不太一样,不能直接获取iteraotr对象,提供的删除方法也是单个的,根据key进行删除,如果我们有个需求,将map中...

前言

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

i. map 迭代删除

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

1. 非常不优雅版本

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

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

list<string> removekey = new arraylist<>();
for (map.entry<string, integer> e: map.entryset()) {
  if (e.getvalue() % 2== 0) {
    removekey.add(e.getkey());
  }
}
removekey.foreach(map::remove);

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

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

2. 正确姿势版

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

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

iterator<map.entry<string, integer>> iterator = map.entryset().iterator();
map.entry<string, integer> entry;
while (iterator.hasnext()) {
  entry = iterator.next();
  if (entry.getvalue() % 2 == 0) {
    iterator.remove();
  }
}
system.out.println(map);

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

3. 简洁版

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

map<string, integer> 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或者有更好的建议,欢迎批评指正,不吝感激

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。