AtomicLong是Java中基于CAS实现的线程安全长整型类,位于java.util.concurrent.atomic包中,用于高效构建并发计数器。它提供incrementAndGet、getAndIncrement、addAndGet等原子方法,支持无锁的线程安全自增、自减、加减指定值、获取当前值及条件更新操作。相比synchronized和ReentrantLock,AtomicLong避免了锁开销,在中低并发场景下性能更优,适用于访问统计、调用计数和唯一ID生成等需求。但在高并发争用时可能因CAS失败导致自旋开销增大,此时建议使用LongAdder替代。此外,其get()方法保证读取最新值,适合强一致性场景,但需注意合理使用set和compareAndSet等方法以避免逻辑错误。
在Java中,AtomicLong 是一个提供原子操作的长整型变量类,常用于多线程环境下实现高效、线程安全的计数器。它位于 java.util.concurrent.atomic 包中,利用底层的CAS(Compare-And-Swap)机制避免了传统锁带来的性能开销,因此在高并发场景下表现优异。
创建一个 AtomicLong 实例非常简单,可以通过默认构造函数初始化为0,或传入初始值:
AtomicLong counter = new AtomicLong(); // 默认值为0
AtomicLong counter2 = new AtomicLong(10); // 初始值为10
这个对象可以在多个线程之间共享,所有对它的增减、读取操作都是原子的,无需额外同步控制。
AtomicLong 提供了多种原子方法来支持常见的计数需求:
crement():先返回当前值,再减1,等价于 i--。例如,实现一个线程安全的请求计数器:
AtomicLong requestCount = new AtomicLong(0);
// 每次有请求时
public void handleRequest() {
long current = requestCount.incrementAndGet();
System.out.println("第 " + current + " 个请求");
}
AtomicLong 特别适合以下场景:
相比使用 synchronized 或 ReentrantLock,AtomicLong 借助CPU级别的CAS指令,在竞争不激烈或中等的情况下性能更高,代码也更简洁。
虽然 AtomicLong 高效,但也有一些需要注意的地方:
基本上就这些。AtomicLong 是实现线程安全计数器的首选工具之一,理解其核心方法和适用边界,能帮助你在并发编程中写出更高效、可靠的代码。