AtomicInteger类的理解及使用

2018-06-18 02:07:31来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

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;
}

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:spring boot 系列之四:spring boot 整合JPA

下一篇:Set<E> 接口简明