AtomicBoolean通过CAS实现布尔值的线程安全操作,提供get、set、compareAndSet等方法,适用于一次性初始化、状态开关等场景,相比synchronized更轻量,避免了锁开销,但不适用于复杂临界区保护。

在Java并发编程中,AtomicBoolean 是 java.util.concurrent.atomic 包提供的一个原子类,用于实现对布尔值的线程安全操作。它通过底层的CAS(Compare-And-Swap)机制保证操作的原子性,避免使用 synchronized 带来的性能开销。下面介绍 AtomicBoolean 的常见用法和实际应用场景。
1. AtomicBoolean 基本用法
AtomicBoolean 提供了几个核心方法来操作布尔值:
- new AtomicBoolean(boolean initialValue):构造函数,设置初始值。
- get():获取当前布尔值。
- set(boolean newValue):设置新值,线程安全。
- compareAndSet(boolean expect, boolean update):如果当前值等于 expect,则更新为 update,返回是否成功。
- getAndSet(boolean newValue):设置新值,并返回旧值。
示例代码:
AtomicBoolean flag = new AtomicBoolean(true);System.out.println(flag.get()); // 输出: true
flag.set(false);
System.out.println(flag.get()); // 输出: false
boolean old = flag.getAndSet(true);
System.out.println(old); // 输出: false
boolean result = flag.compareAndSet(true, false);
System.out.println(result); // 输出: true
2. 实现线程安全的开关控制
一个典型的应用是作为“只执行一次”的控制开关,比如确保某个初始化操作仅运行一次。
立即学习“Java免费学习笔记(深入)”;
public class OneTimeInitializer {private static final AtomicBoolean initialized = new AtomicBoolean(false);
public static void initialize() {
if (initialized.compareAndSet(false, true)) {
System.out.println("执行初始化操作");
// 模拟初始化逻辑
} else {
System.out.println("已初始化,跳过");
}
}
}
多个线程调用 initialize() 方法时,只有第一个能成功将状态从 false 改为 true,其余线程会直接跳过,保证初始化仅执行一次。
3. 替代 volatile 布尔变量进行更复杂的操作
虽然 volatile boolean 可以保证可见性,但不支持复合操作(如“检查再更新”)。AtomicBoolean 弥补了这一点。
例如,在多线程环境下实现状态切换:
AtomicBoolean running = new AtomicBoolean(false);// 启动任务 if (running.compareAndSet(false, true)) {
System.out.println("开始运行");
}
// 停止任务 if (running.compareAndSet(true, false)) {
System.out.println("停止运行");
}
这种方式比使用 synchronized 更轻量,适合高并发场景下的状态管理。
4. 注意事项与最佳实践
- AtomicBoolean 适用于简单的布尔标志操作,不要用于替代锁来保护复杂临界区。
- 它的优势在于无锁(lock-free)设计,减少线程阻塞,提高吞吐量。
- 如果需要统计、计数等操作,应选择 AtomicInteger、AtomicLong 等其他原子类。
- 在高度竞争的场景下,CAS 可能因频繁失败导致自旋,影响性能,需结合业务评估。
基本上就这些。AtomicBoolean 使用简单,但在并发控制中非常实用,尤其适合做状态标记、一次性初始化、开关控制等场景。掌握它的核心方法和适用边界,能有效提升代码的线程安全性与性能。










