Les classes atomiques sont des classes thread-safe en Java qui fournissent des opérations ininterrompues et sont essentielles pour garantir l'intégrité des données dans un environnement concurrent. Java fournit les classes atomiques suivantes : AtomicIntegerAtomicLongAtomicReferenceAtomicBoolean Ces classes fournissent des méthodes pour obtenir, définir et comparer des valeurs afin de garantir que l'opération est atomique et ne sera pas interrompue par des threads. Les classes atomiques sont utiles lorsque vous travaillez avec des données partagées et évitez la corruption des données, comme la gestion de compteurs partagés pour les accès simultanés.
Classes atomiques dans les fonctions Java : un guide critique en matière de concurrence et de multithreading
Présentation des classes atomiques
Les classes atomiques sont des classes thread-safe qui fournissent des opérations qui peuvent être effectuées de manière atomique. Cela signifie que ces opérations sont ininterrompues pour plusieurs threads. Les classes atomiques sont essentielles pour maintenir des données cohérentes dans un environnement concurrent.
Classes atomiques en Java
La bibliothèque standard Java fournit les classes atomiques suivantes :
AtomicInteger
AtomicInteger
AtomicLong
AtomicReference
AtomicBoolean
这些类为基本数据类型(如 int
、long
、boolean
和引用)提供了原子操作。它们具有以下方法:
get()
:获取当前值set()
:设置新值compareAndSet()
:如果当前值等于预期的值,则更新为新值。用法
以下是使用 AtomicInteger
的示例:
// 创建一个 AtomicInteger AtomicInteger counter = new AtomicInteger(); // 以下操作都是原子的 counter.incrementAndGet(); // 获取并递增 counter.addAndGet(10); // 获取并增加 10 counter.compareAndSet(10, 20); // 如果当前值为 10,则更新为 20
实战案例
考虑一个共享计数器的示例。多个线程同时访问此计数器并递增它。如果使用非原子类,则可能会出现数据损坏,因为线程可能会覆盖彼此的更改。可以使用 AtomicInteger
来解决此问题:
public class SharedCounter { // 使用 AtomicInteger 来保证线程安全 private AtomicInteger count = new AtomicInteger(0); public void increment() { count.incrementAndGet(); } public int getCount() { return count.get(); } }
此时,多个线程可以安全地同时调用 increment()
AtomicLong
AtomicBoolean
Ces classes sont des types de données de base (tels que int
, long
, booléen
et références) fournissent des opérations atomiques. Ils ont les méthodes suivantes :
get()
: Récupère la valeur actuelle
set()
: Définit la nouvelle valeur🎜compareAndSet () : si la valeur actuelle est égale à la valeur attendue, mettez à jour vers la nouvelle valeur. 🎜🎜Usage🎜🎜🎜Voici un exemple d'utilisation de AtomicInteger
: 🎜rrreee🎜🎜Exemple pratique🎜🎜🎜Considérons un exemple de compteur partagé. Plusieurs threads accèdent à ce compteur simultanément et l'incrémentent. Si vous utilisez des classes non atomiques, une corruption des données peut se produire car les threads peuvent écraser les modifications des uns et des autres. Ce problème peut être résolu en utilisant AtomicInteger
: 🎜rrreee🎜À ce stade, plusieurs threads peuvent appeler en toute sécurité la méthode increment()
en même temps, et accéder au compteur partagé ne provoque pas de corruption des données. 🎜🎜🎜Conclusion🎜🎜🎜Les classes atomiques sont un outil précieux pour gérer la concurrence et le multithreading en Java. Ils assurent des opérations ininterrompues et peuvent être utilisés pour maintenir des données cohérentes. L'exemple ci-dessus montre comment écrire du code thread-safe à l'aide de classes atomiques 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!