高并发编程-07-JDK提供的原子类操作及原理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高并发编程-07-JDK提供的原子类操作及原理相关的知识,希望对你有一定的参考价值。

1,原子类介绍:

针对数据类型的操作,JDK提供的原子类来方便我们的线程安全控制。

所有的类保存在 java.util.concurrent.atomic 包中

基本数据类型 AtomicInteger

数组类型 AtomicIntegerArray

2,举个使用的例子:

解决之前的 i++ 安全性问题

如何解决?

AtomicInteger count = new AtomicInteger(0);

count.incrementAndGet();//相当于count++,区别是这里可以保证是原子操作

3,原理:

内部的原理是采用了CAS机制,大家可以通过观察源码就可以发现

那么什么是CAS机制?

CAS有人翻译为Compare And Set或Compare And Swap都是正确的。

在多线程并发执行的状态下,锁的状态改变,基本都是使用CAS原理,它有一个比较别扭的叫法“CPU硬件同步原语”,算法是基于CPU硬件的,原子性操作,不会被其他线程打断。

CAS的算法,比较当前值和期望的值是否相等,如果相等,则将当前值赋予一个新值。

再比如修改一个Boolean的类型的变量的值,我们也可以采用

private AtomicBoolean atomicBoolean = new AtomicBoolean(false);

public void lock(){

    //期望是false,如果是false,则可以修改为true

    atomicBoolean.compareAndSet(false, true);

}



以上是关于高并发编程-07-JDK提供的原子类操作及原理的主要内容,如果未能解决你的问题,请参考以下文章

Java Review - 并发编程_原子操作类原理剖析

并发编程系列之掌握原子类使用

并发编程系列之掌握原子类使用

Java 并发编程 进阶 -- ThreadLocalRandom类原理剖析原子操作类原理剖析(AtomicLong)并发List原理剖析(CopyOnWriteArrayList)

Java 并发编程 进阶 -- ThreadLocalRandom类原理剖析原子操作类原理剖析(AtomicLong)并发List原理剖析(CopyOnWriteArrayList)

并发编程之原子类