AtomicBoolean 是 Java 中基于 CAS 实现的线程安全布尔原子类,适用于单次初始化标记、启停开关、二值状态机等轻量同步场景,不依赖锁且操作原子高效。

AtomicBoolean 是 Java 并发包(java.util.concurrent.atomic)中提供的一个线程安全的布尔类型原子类,适合用作轻量级同步控制标志,比如启动/停止开关、初始化完成标记、状态切换哨兵等。它不依赖 synchronized 或 Lock,靠 CPU 级 CAS 指令实现无锁更新,开销小、响应快。
作为单次初始化的“已初始化”标记
常用于双重检查锁定(DCL)单例或延迟初始化场景,替代 volatile boolean 字段,语义更清晰且操作原子。
- 用 compareAndSet(false, true) 尝试设置为 true,仅当当前是 false 时才成功,天然保证只执行一次初始化逻辑
- 比手动写 volatile + 同步块更简洁,避免忘记加锁或误判可见性
- 例如:静态内部类单例不适用,但实例内懒加载资源(如缓存、连接池)很合适
充当运行状态开关(如 start/stop 控制)
适用于需要被多个线程读写、但只需二值状态(运行中 / 已停止)的组件,比如定时任务控制器、事件监听器生命周期管理。
- start() 方法调用 set(true),stop() 调用 set(false),读取直接用 get()
- 若需“仅在运行中才执行某动作”,可用 get() && doWork(),无需同步块
- 注意:它不阻塞线程,也不提供等待机制;如需“等待停止完成”,应配合 CountDownLatch 或其他协调工具
实现简单的无锁状态机流转
当状态只有两个(如“就绪↔处理中”、“空闲↔忙碌”),AtomicBoolean 可低成本建模,避免引入复杂状态枚举和锁。
立即学习“Java免费学习笔记(深入)”;
- 例如:一个线程安全的简易限流器,用 AtomicBoolean 表示“是否正在刷新令牌”,防止重复触发刷新
- 关键操作用 compareAndSet(expected, updated) 实现条件更新,失败即说明状态已被其他线程改变,可重试或跳过
- 不适合多状态(>2)场景;此时建议用 AtomicInteger 或 Enum + AtomicReference
基本上就这些。AtomicBoolean 不是万能锁替代品,但它在“单比特、单次变更、高读频、低写频”的控制场景下,既安全又高效,写起来也干净。










