反復中にHashSetから要素を削除する [重複] 質問する

反復中にHashSetから要素を削除する [重複] 質問する

Javaから要素を削除しようとするとハッシュセット繰り返し処理をすると、同時変更例外要素のサブセットを削除する最良の方法は何ですか?ハッシュセット次の例のように?

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);

ありがとう!

ベストアンサー1

セットの要素を手動で反復処理できます。

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

forこのパターンでは、 loop ではなく loop が使用されることがよくありますwhile

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

指摘されているように、ループを使用すると、for反復子変数 (iこの場合は) がより狭い範囲に限定されるため、ループを使用することをお勧めします。

おすすめ記事