Heim >Java >javaLernprogramm >Wie vermeide ich ConcurrentModificationException beim Entfernen von Elementen aus einer Sammlung während der Iteration?

Wie vermeide ich ConcurrentModificationException beim Entfernen von Elementen aus einer Sammlung während der Iteration?

DDD
DDDOriginal
2024-12-08 14:15:14318Durchsuche

How to Avoid ConcurrentModificationException When Removing Elements from a Collection During Iteration?

ConcurrentModificationException beim Entfernen von Sammlungselementen während der Iteration vermeiden

Einführung

Eine Sammlung gleichzeitig ändern Das Durchlaufen kann zu unerwartetem Verhalten führen, einschließlich einer ConcurrentModificationException. Um dieses Problem zu vermeiden, können verschiedene Ansätze verwendet werden.

Ansatz 1: Iterieren über eine Sammlungskopie

Eine Methode besteht darin, eine Kopie der Sammlung zu erstellen und darüber zu iterieren diese Kopie anstelle der Originalsammlung. Dadurch wird sichergestellt, dass die ursprüngliche Sammlung während der Iteration nicht geändert wird.

Beispiel:

List<Foo> fooListCopy = new ArrayList<>(fooList);
for (Foo foo : fooListCopy) {
    // Modify the actual fooList
}

Ansatz 2: Verwendung des Sammlungsiterators

Ein anderer Ansatz besteht darin, den von der Originalsammlung bereitgestellten Iterator zu verwenden. Der Iterator bietet eine sichere Möglichkeit, die Sammlung zu durchlaufen und Elemente während der Iteration zu entfernen.

Beispiel:

Iterator<Foo> itr = fooList.iterator();
while (itr.hasNext()) {
    // Modify the actual fooList using itr.remove()
}

Alternative Ansätze mit JDK 8 oder Höher

  • removeIf: Diese Methode nimmt ein Prädikat und entfernt alle Elemente, die das Prädikat erfüllen, aus der Sammlung.
  • Streams: Mithilfe von Streams können Sie die Sammlung filtern, um eine neue Sammlung mit den gewünschten Elementen zu erstellen, und dann die ursprüngliche Sammlung durch die gefilterte ersetzen Sammlung.

Berücksichtigung bei der Auswahl

Der beste Ansatz hängt vom jeweiligen Szenario ab:

  • Sammeln und Entfernen : Funktioniert mit jeder Sammlung, erfordert jedoch zwei Iterationen.
  • ListIterator: Effizient für Listen und unterstützt Hinzufügungs- und Entfernungsvorgänge.
  • Iterator: Unterstützt nur Entfernungsvorgänge.
  • JDK 8 Streams: Iteriert einmal und filtert effizient Elemente.
  • Unterliste oder Teilmenge: Effizient zum Entfernen aufeinanderfolgender Elemente in einer sortierten Sammlung.

Zusätzliche Überlegungen umfassen:

  • Der Kopieransatz ist sicher, verursacht jedoch die Kosten für das Kopieren der Sammlung.
  • Der Iterator-Ansatz wird möglicherweise nicht unterstützt von allen Iterator-Implementierungen.
  • JDK 8-Streams ändern den Verweis auf die Sammlung, was eine Neuzuweisung erfordert.

Das obige ist der detaillierte Inhalt vonWie vermeide ich ConcurrentModificationException beim Entfernen von Elementen aus einer Sammlung während der Iteration?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn