Gérer l'accès simultané aux listes en Java
L'utilisation de collections dans des environnements multithread peut introduire des problèmes de concurrence. Cet article explore la disponibilité d'une implémentation de liste concurrente dans le kit de développement Java (JDK) et propose une solution alternative.
Quête d'une liste concurrente
Pouvons-nous créer une liste concurrente qui permet l'accès aux éléments indexés ? Le JDK fournit-il des classes prêtes à l'emploi ou des méthodes d'usine à cet effet ?
Solution : ConcurrentLinkedQueue
Bien que le JDK n'offre pas d'implémentation directe d'une liste concurrente avec un accès basé sur l'index, il existe une solution alternative qui préserve l'ordre d'insertion : java.util.concurrent.ConcurrentLinkedQueue.
Cette classe sacrifie l'accès indexé mais maintient l'ordre en implémentant Iterable. Une fois tous les éléments ajoutés, il permet l'itération en utilisant une syntaxe for améliorée :
Queue<String> globalQueue = new ConcurrentLinkedQueue<>(); // Multiple threads can safely call globalQueue.add() for (String href : globalQueue) { // Perform operations on href }
Cette solution garantit des insertions sécurisées pour les threads tout en fournissant un moyen de traiter les éléments dans l'ordre dans lequel ils ont été ajoutés, résolvant ainsi le défi de la liste simultanée. accès en Java.
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!