因此,如果我尝试在迭代时从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);
谢谢!
您可以手动遍历集合的元素:
Iterator<Integer> iterator = set.iterator(); while (iterator.hasNext()) { Integer element = iterator.next(); if (element % 2 == 0) { iterator.remove(); } }
您通常会使用for循环而不是while循环来查看此模式:
for
while
for (Iterator<Integer> i = set.iterator(); i.hasNext();) { Integer element = i.next(); if (element % 2 == 0) { i.remove(); } }
正如人们指出的那样,使用for循环是优选的,因为这样可以将迭代器变量(i在这种情况下)限制在较小的范围内。
i