一尘不染

重复执行时从HashSet中删除元素

java

因此,如果我尝试在迭代时从Java HashSet中 删除元素,则会收到 ConcurrentModificationException
。如下例所示,从 HashSet中 删除元素子集的最佳方法是什么?

Set<Integer> set = new HashSet<Integer>();

for(int i = 0; i < 10; i++)
    set.add(i);

// Throws ConcurrentModificationException
for(Integer element : set)
    if(element % 2 == 0)
        set.remove(element);

这是一个解决方案,但我认为它不是很优雅:

Set<Integer> set = new HashSet<Integer>();
Collection<Integer> removeCandidates = new LinkedList<Integer>();

for(int i = 0; i < 10; i++)
    set.add(i);

for(Integer element : set)
    if(element % 2 == 0)
        removeCandidates.add(element);

set.removeAll(removeCandidates);

谢谢!


阅读 224

收藏
2020-09-09

共1个答案

一尘不染

您可以手动遍历集合的元素:

Iterator<Integer> iterator = set.iterator();
while (iterator.hasNext()) {
    Integer element = iterator.next();
    if (element % 2 == 0) {
        iterator.remove();
    }
}

您通常会使用for循环而不是while循环来查看此模式:

for (Iterator<Integer> i = set.iterator(); i.hasNext();) {
    Integer element = i.next();
    if (element % 2 == 0) {
        i.remove();
    }
}

正如人们指出的那样,使用for循环是优选的,因为这样可以将迭代器变量(i在这种情况下)限制在较小的范围内。

2020-09-09