Heim >Java >javaLernprogramm >Warum erhalte ich eine ConcurrentModificationException, selbst wenn ich Synchronized verwende?
ConcurrentModificationException bei Verwendung von Synchronized
Trotz der Synchronisierung der getAnotherX-Methode stoßen Sie beim Aufruf von iterator.next() auf eine ConcurrentModificationException-Ausnahme. Um zu verstehen, warum dies geschieht, ist es wichtig, die Natur der ConcurrentModificationException zu verstehen.
Natur der ConcurrentModificationException
Im Gegensatz zu ihrem Namen wird ConcurrentModificationException nicht hauptsächlich durch mehrere Threads verursacht . Dies tritt häufig auf, wenn die Sammlung, über die innerhalb der Iterationsschleife iteriert wird, geändert wird. Hier ist ein Beispiel:
Iterator iterator = collection.iterator(); while (iterator.hasNext()) { Item item = (Item) iterator.next(); if (item.satisfiesCondition()) { collection.remove(item); } }
In diesem Szenario ist die Verwendung von iterator.remove() anstelle voncollection.remove(item) unerlässlich. Diese Ausnahme kann auch beim Hinzufügen zur Sammlung auftreten. Leider gibt es für diesen Fall keine allgemeingültige Lösung. Wenn Sie jedoch mit einer Liste arbeiten, können Sie ListIterator verwenden, der über eine add()-Methode verfügt.
Das obige ist der detaillierte Inhalt vonWarum erhalte ich eine ConcurrentModificationException, selbst wenn ich Synchronized verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!