AtomicInteger在多线程并发场景的使用
AtomicInteger提供原子操作来进行Integer的使用,因此十分适合高并发情况下的使用。
AtomicInteger位于包package java.util.concurrent.atomic下,主要源码如下:
首先看到改类里有两个私有的静态变量unsafe和valueOffset,unsafe在jdk源码里通过Unsafe.getUnsafe()得到,但是我们自己是没办法
在代码里直接调用这个静态方法的,因为这个方法在调用时会判断类加载器,我们的代码是没有"受信用"的,而jdk源码没问题.
valueOffset是指类中相应字段在类中的偏移量,具体指value这个字段在AtomicInteger类的内存中相对于该类的首地址的偏移量.
该类里有一个变量value是volatile关键字修饰的,作用是多个线程可以共享该变量,但是此关键字效率比较低,会使虚拟机失去优化作用,
因此,AtomicInteger不要随意使用,要在适用场景下使用.
此类有个比较常用的方法是compareAndSet,当调用该方法时,若value值与expect值相等,则将value值更改为update,返回true,若value值
与expect值不相等,返回false,不做任何操作.
public final boolean compareAndSet(int expect, int update) {
return unsafe.compareAndSwapInt(this, valueOffset, expect, update);
}
下面代码作用可以阻止其他线程进入方法:
AtomicInteger mutex = new AtomicInteger(0);
if (!mutex.compareAndSet(0, 1)) {
return;
}