AtomicBoolean通过CAS机制实现线程安全的布尔操作,提供get、set、compareAndSet等原子方法,适用于多线程下的状态控制,如单次初始化;相比volatile boolean,它能保证比较并设置的原子性,避免竞态条件,是轻量级线程安全标志的理想选择。

在Java中,AtomicBoolean 是 java.util.concurrent.atomic 包提供的一个用于实现线程安全布尔标志的类。它通过底层的CAS(Compare-And-Swap)机制保证对布尔值的读取、写入和比较交换操作是原子的,适用于多线程环境下作为开关或状态标志使用。
创建一个AtomicBoolean对象非常简单,可以通过默认构造函数初始化为 false,也可以传入一个boolean值指定初始状态。
常用方法包括:
AtomicBoolean flag = new AtomicBoolean(false); // 获取当前值 boolean currentValue = flag.get(); // 设置为true flag.set(true); // 比较并设置 boolean success = flag.compareAndSet(true, false); // 若当前为true,则设为false // 获取旧值并设置新值 boolean oldValue = flag.getAndSet(true);
AtomicBoolean常用于控制线程执行流程,比如实现“只执行一次”逻辑、启动/停止标志等。
立即学习“Java免费学习笔记(深入)”;
典型应用场景:线程安全的初始化操作
public class SingletonWithInitFlag {
private static final AtomicBoolean initialized = new AtomicBoolean(false);
public void initialize() {
if (initialized.compareAndSet(false, true)) {
// 只有第一个调用的线程能进入
System.out.println("执行初始化逻辑");
// 初始化代码...
} else {
System.out.println("已初始化,跳过");
}
}
}
多个线程同时调用 initialize() 方法时,只有其中一个能将标志从 false 更新为 true,从而确保初始化逻辑仅执行一次。
虽然使用 volatile boolean 也能保证可见性,但它不提供原子的“比较并设置”操作。例如以下代码存在竞态条件:
volatile boolean flag = false;
// 多线程中执行:
if (!flag) {
flag = true; // 非原子操作,可能多个线程同时进入
}
而使用 AtomicBoolean 的 compareAndSet 能保证该操作的原子性,避免此类问题。
Lock 或其他并发工具
基本上就这些。AtomicBoolean使用简单,但在高并发控制中作用关键,是实现轻量级线程安全标志的理想选择。
以上就是在Java中如何使用AtomicBoolean实现原子标志变量_AtomicBoolean使用方法说明的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号