这篇文章主要介绍“Java并发编程之原子类怎么应用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java并发编程之原子类怎么应用”文章能帮助大家解决问题。
原子数组有AtomicIntegerArray
、AtomicLongArray
、AtomicReferenceArray
,主要是用来对数组中的某个元素进行原子操作。三个类的方法基本类似,这里只介绍一下AtomicIntegerArray
的方法。
两个构造方法,第一个构造方法传入数组长度初始化一个所有值都为0
的数组,第二个构造方法直接传入一个数组来进行初始化。
public AtomicIntegerArray(int length) public AtomicIntegerArray(int[] array)
先获取数组中索引为i
的值,然后对它进行加1
public final int getAndIncrement(int i)
先获取数组中索引为i
的值,然后对它进行减1
public final int getAndDecrement(int i)
先对数组中索引为i
的值进行加1
,然后获取新值
public final int incrementAndGet(int i)
先对数组中索引为i的值进行减1,然后获取新值
public final int decrementAndGet(int i)
先对数组中索引为i
的值进行加delta
,然后获取新值
public final int addAndGet(int i, int delta)
先获取数组中索引为i的值,然后对它进行加delta
public final int getAndAdd(int i, int delta)
先获取数组中索引为i
的值,然后把它设置为newValue
public final int getAndSet(int i, int newValue)
先获取数组中索引为i
的值,然后执行指定的操作对其进行更新
public final int getAndUpdate(int i, IntUnaryOperator updateFunction)
先执行指定的操作对其进行更新,然后获取新值
public final int updateAndGet(int i, IntUnaryOperator updateFunction)
原子更新器有AtomicIntegerFieldUpdater
、AtomicLongFieldUpdater
、AtomicReferenceFieldUpdater
,它们的作用是对某个对象的某个属性进行原子操作,同样三个类的操作基本相同,只是属性的类型不同而已,这里以AtomicIntegerFieldUpdater
为例介绍基本方法。
类中提供了一个静态方法来创建对象,两个参数分别是tclass
:要操作的类,fieldName
:要操作的类的属性名
public static <U> AtomicIntegerFieldUpdater<U> newUpdater(Class<U> tclass, String fieldName)
先获取对象obj
的属性fieldName
的值,然后对其进行自增1
操作
public int getAndIncrement(T obj)
先获取对象obj
的属性fieldName
的值,然后对其进行自减1
操作
public int getAndDecrement(T obj)
先把对象obj
的属性fieldName
的值进行自增1
,然后获取新值
public int incrementAndGet(T obj)
先把对象obj
的属性fieldName
的值进行自减1
,然后获取新值
public int decrementAndGet(T obj)
先获取对象obj
的属性fieldName
的值,然后对其加delta
public int getAndAdd(T obj, int delta)
先把对象obj
的属性fieldName
的值加delta
,然后获取新值
public int addAndGet(T obj, int delta)
先获取对象obj
的属性fieldName
的值,然后把它的值设为newValue
public int getAndSet(T obj, int newValue)
先获取对象obj
的属性fieldName
的值,然后执行指定的操作把更新它的值
public final int getAndUpdate(T obj, IntUnaryOperator updateFunction)
原子累加器LongAdder
是jdk1.8
新增的一个类,它的作用和AtomicInteger
、AtomicLong
类似,但是在多线程情况下它的性能要高很多,原因是LongAdder
维护了一个Cell
数组,累加操作时每个线程对其中一个数据进行操作,最后再把结果进行汇总,提高了并发性。
无参构造方法什么也没有做,默认累加器的结果就是0
public LongAdder()
sum
方法就是对Cell
数组中各单元的值进行求和,然后返回当前累加器的值
public long sum()
累加器自增1
public void increment()
累加器自减1
public void decrement()
累加器加x
public void add(long x)
累加器的值重置为0
public void reset()
先获取累加器的值,然后再重置为0
public long sumThenReset()
关于“Java并发编程之原子类怎么应用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。