我是靠谱客的博主 繁荣枫叶,这篇文章主要介绍Java删除Map中元素,现在分享给大家,希望可以做个参考。

前言:

关于Java从Map中删除元素的使用,可以使用删除单个元素的事实Map.remove

示例:

初始化一个Map对象

复制代码
1
2
3
4
5
6
Map<Integer, String> map = new HashMap<>(); map.put(1, "value 1"); map.put(2, "value 2"); map.put(3, "value 3"); map.put(4, "value 4"); map.put(5, "value 5");复制代码

有几种方法可以删除元素:

复制代码
1
2
3
4
5
6
for(Iterator<Integer> iterator = map.keySet().iterator(); iterator.hasNext(); ) { Integer key = iterator.next(); if(key != 1) { iterator.remove(); } }复制代码

如果不使用Java 8+,就可以使用Iterator以防止 ConcurrentModificationException异常

如果您使用的

较新
版本的Java(8+),那么您可以这样:

复制代码
1
2
3
4
5
6
// 通过value移除 map.values().removeIf(value -> !value.contains("1")); // 通过key移除 map.keySet().removeIf(key -> key != 1); // 通过键/值的输入/组合删除 map.entrySet().removeIf(entry -> entry.getKey() != 1);复制代码

removeIfCollection s 的方法。一个Map本身不是一个Collection,也无法访问removeIf自己。但是通过使用:valueskeySetentrySet 此实现Collection允许removeIf在其上调用。

内容返回的valueskeySet而且entrySet是非常重要的。以下是JavaDoc的说明摘要values

复制代码
1
2
3
4
5
6
7
8
* Returns a {@link Collection} view of the values contained in this map. * The collection is backed by the map, so changes to the map are * reflected in the collection, and vice-versa. * * The collection supports element removal, which removes the corresponding * mapping from the map, via the {@code Iterator.remove}, * {@code Collection.remove}, {@code removeAll}, * {@code retainAll} and {@code clear} operations.复制代码

这个JavaDoc解释了Collection返回的values是由它支持的。文档指定Iterator.remove可以使用。此外实现removeIfIterator示例如下。

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
default boolean removeIf(Predicate<? super E> filter) { Objects.requireNonNull(filter); boolean removed = false; final Iterator<E> each = iterator(); while (each.hasNext()) { if (filter.test(each.next())) { each.remove(); removed = true; } } return removed; }复制代码

总结:

使用 valueskeySetentrySet接入removeIf 更容易移除Map中的元素。



转载于:https://juejin.im/post/5cf600ec518825710c63806b

最后

以上就是繁荣枫叶最近收集整理的关于Java删除Map中元素的全部内容,更多相关Java删除Map中元素内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(92)

评论列表共有 0 条评论

立即
投稿
返回
顶部