


Comment éviter ConcurrentModificationException lors de la suppression d'éléments d'une collection au cours d'une itération ?
Dec 08, 2024 pm 02:15 PMÉ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!

Outils chauds Tags

Article chaud

Outils chauds Tags

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Comment fonctionne le mécanisme de chargement de classe de Java, y compris différents chargeurs de classe et leurs modèles de délégation?

Comment utiliser Maven ou Gradle pour la gestion avancée de projet Java, la création d'automatisation et la résolution de dépendance?

Top 4 frameworks JavaScript en 2025: React, Angular, Vue, Svelte

Comment puis-je implémenter des techniques de programmation fonctionnelle en Java?

Iceberg: L'avenir des tables de Data Lake

Comment puis-je utiliser JPA (Java Persistance API) pour la cartographie relationnelle des objets avec des fonctionnalités avancées comme la mise en cache et le chargement paresseux?

Comment implémenter la mise en cache à plusieurs niveaux dans les applications Java à l'aide de bibliothèques comme la caféine ou le cache de goyave?

Comment utiliser l'API NIO (nouvelle entrée / sortie) de Java pour les E / S non bloquantes?
