AtomicBoolean适用于开关状态的原子操作,如初始化标志,通过compareAndSet保证线程安全;AtomicLong用于高性能计数场景,支持原子增减和累积操作,可替代synchronized实现高效并发计数。
在Java并发编程中,AtomicBoolean 和 AtomicLong 是 java.util.concurrent.atomic 包下的两个常用原子类。它们通过底层CAS(Compare-And-Swap)操作保证线程安全,避免使用 synchronized 带来的性能开销。合理使用这两个类,可以提升高并发场景下的程序效率和可读性。
AtomicBoolean 适合用来表示开关类的状态,比如“是否初始化”、“任务是否完成”等。它的值只能是 true 或 false,但提供了线程安全的读写和条件更新操作。
if (initialized.compareAndSet(false, true)) {
// 执行初始化逻辑
}
AtomicLong 是 long 类型的原子包装类,常用于统计、序列号生成、指标监控等需要线程安全递增的场景。
ile 读写的内存可见性,但复合操作仍需原子方法保障。基本上就这些。AtomicBoolean 和 AtomicLong 看似简单,但在实际开发中正确使用能有效减少并发问题。关键是理解它们提供的原子操作语义,避免手动拆解为非原子步骤。不复杂但容易忽略。