共计 1242 个字符,预计需要花费 4 分钟才能阅读完成。
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 或者有更好的建议,欢迎批评指正,不吝感激
- 微博地址: 小灰灰 Blog
- QQ:一灰灰 /3302797840
- 个人站点 一灰灰 Blog:https://liuyueyi.github.io/he…
正文完
发表至: java
2019-05-29