Thread-Safe ArrayList en Java : exploration d'une autre approche
Un défi courant dans la programmation multithread est d'assurer la sécurité des structures de données partagées, comme ArrayList. Dans ce scénario, une classe Race gère une ArrayList pour capturer les objets RaceCar à la fin de leur exécution. Cependant, ArrayList n'est pas intrinsèquement thread-safe, ce qui soulève des préoccupations quant à l'intégrité des données.
Initialement, une tentative a été faite pour utiliser Collections.synchronizedCollection(c Collection) pour créer une ArrayList thread-safe. Cependant, le compilateur s'y est opposé, indiquant une inadéquation entre le type Collection et le type ArrayList souhaité.
Approche alternative : Collections.synchronizedList()
Une approche efficace pour atteindre la sécurité des threads avec une ArrayList consiste à utiliser la méthode Collections.synchronizedList(). Cette méthode renvoie une liste thread-safe, soutenue par une ArrayList sous-jacente, qui permet au programme de continuer à utiliser l'interface ArrayList pour manipuler les données.
Pour implémenter cette approche, le segment de code suivant peut être utilisé :
<code class="java">List<RaceCar> finishingOrder = Collections.synchronizedList(new ArrayList<>());</code>
Avec cette modification, l'ArrayList est désormais protégée contre les accès simultanés, garantissant que l'ordre dans lequel les objets RaceCar terminent la course est maintenu avec précision.
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!