AtomicInteger通过CAS实现线程安全的整数操作,提供get、set、自增、自减及compareAndSet等原子方法,适用于高并发计数场景,性能优于synchronized。

在Java中,AtomicInteger 是 java.util.concurrent.atomic 包下的一个类,它提供了线程安全的整数操作,而无需使用 synchronized 关键字。它通过底层的 CAS(Compare-And-Swap)机制实现原子性,适合高并发场景下的计数器、状态标志等用途。
可以通过默认构造函数创建值为0的 AtomicInteger,或传入初始值:
AtomicInteger 提供了一系列原子方法,用于安全地修改其内部值:
下面是一个多线程环境下使用 AtomicInteger 实现计数器的简单例子:
立即学习“Java免费学习笔记(深入)”;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class CounterExample {
private static AtomicInteger count = new AtomicInteger(0);
public static void main(String[] args) {
ExecutorService executor = Executors.newFixedThreadPool(10);
for (int i = 0; i < 1000; i++) {
executor.submit(() -> {
count.incrementAndGet();
});
}
executor.shutdown();
while (!executor.isTerminated()) {}
System.out.println("最终计数值: " + count.get());
}
}
即使多个线程同时调用 incrementAndGet(),结果也一定是 1000,不会出现线程安全问题。
该方法可用于实现无锁的条件更新。例如,只在当前值为 5 时才更新为 10:
基本上就这些。AtomicInteger 在保证线程安全的同时性能优于 synchronized,特别适用于读多写少或竞争不激烈的场景。关键是理解它的原子性来源于底层的 volatile 和 CAS 操作,而不是锁。
以上就是在Java中如何使用AtomicInteger实现原子操作的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号