AtomicBoolean适用于开关状态的原子操作,如初始化标志,通过compareAndSet保证线程安全;AtomicLong用于高性能计数场景,支持原子增减和累积操作,可替代synchronized实现高效并发计数。

在Java并发编程中,AtomicBoolean 和 AtomicLong 是 java.util.concurrent.atomic 包下的两个常用原子类。它们通过底层CAS(Compare-And-Swap)操作保证线程安全,避免使用 synchronized 带来的性能开销。合理使用这两个类,可以提升高并发场景下的程序效率和可读性。
AtomicBoolean:状态标志的首选
AtomicBoolean 适合用来表示开关类的状态,比如“是否初始化”、“任务是否完成”等。它的值只能是 true 或 false,但提供了线程安全的读写和条件更新操作。
- 使用 compareAndSet(expect, update) 实现“仅设置一次”的逻辑。例如,防止重复初始化:
if (initialized.compareAndSet(false, true)) {
// 执行初始化逻辑
}
- 避免使用 get() + set() 组合判断,这会破坏原子性。始终优先使用 compareAndSet 或 getAndSet。
- getAndSet(newValue) 可用于“获取旧值并设置新值”,适用于需要“消费”当前状态的场景。
AtomicLong:高性能计数器
AtomicLong 是 long 类型的原子包装类,常用于统计、序列号生成、指标监控等需要线程安全递增的场景。
JSPGOU一直以来都和jeecms、jeebbs一样,是收费软件,但是从2014年7月12日开始,开始jspgou发布第一个免费版,金磊科技承诺:永远不向使用jspgou免费版用户索取任何费用,为免费用户提供更好的技术支持服务,根据用户提出的完善建议快速完善jspgou系统。 jspgou系统使命:做中国最优秀的免费网店系统,让更多的用户了解和使用java产品。 jspgou免费版适用对象:不限
- 替代 synchronized 方法中的 long++ 操作。直接调用 incrementAndGet() 或 getAndIncrement() 更简洁高效。
- 支持 addAndGet(long delta),可用于加减任意数值,比如扣减库存或累计请求量。
- 在极端高并发下,如果发现性能瓶颈,可考虑使用 LongAdder 替代 AtomicLong。LongAdder 在写多读少的场景下性能更好,但占用更多内存。
常见使用误区与建议
- 不要把 AtomicBoolean 当作锁使用。它不支持阻塞和重入,复杂同步应使用 Lock 或 synchronized。
- AtomicLong 的初始值要明确设置,避免默认为 0 导致逻辑错误。
- 在日志或监控中打印 AtomicLong 的值时,使用 get() 获取快照即可,无需额外同步。
- 注意 volatile 语义:Atomic 类的 get/set 具备 volatile 读写的内存可见性,但复合操作仍需原子方法保障。
基本上就这些。AtomicBoolean 和 AtomicLong 看似简单,但在实际开发中正确使用能有效减少并发问题。关键是理解它们提供的原子操作语义,避免手动拆解为非原子步骤。不复杂但容易忽略。









