在AtomicInteger类的getAndIncrement方法中,自旋是使用CAS(Compare And Swap)操作来实现原子性的方法,确保多个线程并发访问时,只有一个线程可以处于修改状态。如果CAS失败,那么线程会继续循环执行CAS操作,直到成功为止。
代码示例:
public class AtomicIntegerDemo {
private static AtomicInteger atomicInteger = new AtomicInteger(0);
public static void main(String[] args) {
ExecutorService executorService = Executors.newFixedThreadPool(10);
for (int i = 0; i < 10; i++) {
executorService.execute(new Runnable() {
@Override
public void run() {
int value = atomicInteger.getAndIncrement();
System.out.println(Thread.currentThread().getName() + " get value:" + value);
}
});
}
executorService.shutdown();
}
}
输出结果:
pool-1-thread-4 get value:2
pool-1-thread-3 get value:1
pool-1-thread-2 get value:0
pool-1-thread-8 get value:7
pool-1-thread-1 get value:3
pool-1-thread-5 get value:4
pool-1-thread-6 get value:5
pool-1-thread-7 get value:6
pool-1-thread-10 get value:9
pool-1-thread-9 get value:8
在这个示例中,我们使用了AtomicInteger类的getAndIncrement方法来获取并递增它的值。由于多个线程可能同时访问它,因此自旋是必要的,以确保操作的原子性。每个线程获取的值都是唯一的。