AtomicInteger 简介与常规用法
AtomicInteger是 Java 中java.util.concurrent.atomic包下的一个类。用于实现原子操作的整数。它是一个基于CAS(Compare-And-Swap)实现的原子整数类。它提供了一系列的原子操作,确保对整数的操作是原子性的,不会受到其他线程的干扰。
CAS想详细了解,看这篇文章=》CAS的的底层
在并发编程中,当多个线程对同一个整数进行操作时,可能会出现竞态条件(Race Condition),为了避免这种情况,可以使用 AtomicInteger 来确保对整数的操作是原子性的。
主要方法
AtomicInteger 提供了一系列的原子操作方法,其中常见的包括:
get():获取当前的值。set(int newValue):设置新的值。getAndIncrement():先获取当前的值,然后再增加1。incrementAndGet():先增加1,然后再获取当前的值。getAndSet(int newValue):获取当前的值并设置新的值。compareAndSet(int expect, int update):如果当前值等于期望值,则更新为新值。
常规用法示例
以下是一个简单的示例,展示了如何在多线程环境中使用 AtomicInteger:
import java.util.concurrent.atomic.AtomicInteger;public class AtomicIntegerExample {public static void main(String[] args) {AtomicInteger atomicInteger = new AtomicInteger(0);// 启动多个线程并发地增加值for (int i = 0; i < 5; i++) {new Thread(() -> {for (int j = 0; j < 1000; j++) {atomicInteger.incrementAndGet();}}).start();}// 等待所有线程完成try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}// 输出最终的值System.out.println("Final Value: " + atomicInteger.get());}
}
在这个例子中,我们创建了一个初始值为 0 的 AtomicInteger 对象,并启动了 5 个线程,每个线程对该对象进行 1000 次的增加操作。通过 incrementAndGet 方法,AtomicInteger 保证了对整数的增加操作是原子的,不会出现竞态条件。

这个示例输出的最终值应该是 5000,因为每个线程增加了 1000 次。使用 AtomicInteger 能够确保在并发环境中正确地进行原子操作,避免了多线程竞争导致的问题。