登录
首页 >  文章 >  java教程

AtomicBoolean与AtomicLong实用技巧解析

时间:2026-04-16 10:35:27 180浏览 收藏

AtomicBoolean和AtomicLong作为Java并发编程中轻量高效的原子工具,分别专精于线程安全的状态开关控制与高性能计数场景——前者通过compareAndSet等原子操作杜绝重复初始化或状态竞态,后者以CAS替代synchronized实现无锁递增、累加与统计,显著提升高并发下的性能与代码可读性;掌握其核心语义、规避常见误用(如当锁使用或拆分原子操作),能让开发者在不引入复杂同步机制的前提下,写出更健壮、更简洁的并发代码。

Java中AtomicBoolean和AtomicLong使用技巧

在Java并发编程中,AtomicBooleanAtomicLong 是 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 类型的原子包装类,常用于统计、序列号生成、指标监控等需要线程安全递增的场景。

  • 替代 synchronized 方法中的 long++ 操作。直接调用 incrementAndGet()getAndIncrement() 更简洁高效。
  • 支持 addAndGet(long delta),可用于加减任意数值,比如扣减库存或累计请求量。
  • 在极端高并发下,如果发现性能瓶颈,可考虑使用 LongAdder 替代 AtomicLong。LongAdder 在写多读少的场景下性能更好,但占用更多内存。

常见使用误区与建议

  • 不要把 AtomicBoolean 当作锁使用。它不支持阻塞和重入,复杂同步应使用 Lock 或 synchronized。
  • AtomicLong 的初始值要明确设置,避免默认为 0 导致逻辑错误。
  • 在日志或监控中打印 AtomicLong 的值时,使用 get() 获取快照即可,无需额外同步。
  • 注意 volatile 语义:Atomic 类的 get/set 具备 volatile 读写的内存可见性,但复合操作仍需原子方法保障。

基本上就这些。AtomicBoolean 和 AtomicLong 看似简单,但在实际开发中正确使用能有效减少并发问题。关键是理解它们提供的原子操作语义,避免手动拆解为非原子步骤。不复杂但容易忽略。

以上就是《AtomicBoolean与AtomicLong实用技巧解析》的详细内容,更多关于的资料请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>