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

}