Maison >Java >javaDidacticiel >Comment éviter ConcurrentModificationException lors de la suppression d'éléments d'une collection au cours d'une itération ?

Comment éviter ConcurrentModificationException lors de la suppression d'éléments d'une collection au cours d'une itération ?

DDD
DDDoriginal
2024-12-08 14:15:14273parcourir

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

Éviter l'exception ConcurrentModificationException lors de la suppression d'éléments de collection pendant l'itération

Introduction

Modifier une collection simultanément le parcourir peut entraîner un comportement inattendu, notamment une ConcurrentModificationException. Pour éviter ce problème, différentes approches peuvent être utilisées.

Approche 1 : Itérer sur une copie de collection

Une méthode consiste à créer une copie de la collection et à parcourir cette copie au lieu de la collection originale. Cela garantit que la collection d'origine n'est pas modifiée pendant l'itération.

Exemple :

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

Approche 2 : Utilisation de l'itérateur de collection

Une autre approche consiste à utiliser l'itérateur fourni par la collection d'origine. L'itérateur fournit un moyen sûr de parcourir la collection et de supprimer des éléments lors de l'itération.

Exemple :

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

Approches alternatives avec JDK 8 ou supérieur

  • removeIf : Ceci La méthode prend un prédicat et supprime tous les éléments qui satisfont le prédicat de la collection.
  • Streams : À l'aide des flux, vous pouvez filtrer la collection pour créer une nouvelle collection avec les éléments souhaités, puis remplacer la collection originale avec la collection filtrée.

Considération pour Sélection

La meilleure approche dépend du scénario spécifique :

  • Collecter et supprimer : Fonctionne avec n'importe quelle collection mais nécessite deux itérations.
  • ListIterator : Efficace pour l'ajout et la suppression de listes et de supports opérations.
  • Itérateur : Prend uniquement en charge les opérations de suppression.
  • JDK 8 Streams : Itère une fois et filtre efficacement les éléments.
  • Sous-liste ou sous-ensemble : Efficace pour supprimer des éléments consécutifs dans un tri collection.

Considérations supplémentaires :

  • L'approche de copie est sûre mais entraîne le coût de la copie de la collection.
  • L'approche itérateur peut ne pas être prise en charge par toutes les implémentations d'itérateurs.
  • Les flux JDK 8 modifient la référence à la collection, nécessitant un réaffectation.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn