jdk:1.8.0_65
1 前言
首先需要了解什么是原子性,可以理解为CPU层面不能分割的操作,原子性只有两种状态,要么改变,要么不改变。如果多线程同时更新同一个变量,非原子操作都会出现线程安全问题,导致多线程执行后获取到的变量值与期望值不一致。
那么如何解决线程安全问题呢,可以实现一个原子操作,有三种方式:
第一种:使用同步技术,sychronized代码块。
第二种:lock接口。
第三种:原子数据结构,如AtomicBoolean、AtomicInteger、AtomicLong等。
以下是针对原子数据结构进行解读。
2.原子数据结构
原子数据在jdk中包路径为java.util.concurrent.atomic,原子数据结构类都是使用Unsafe实现的包装类,有11个类,可以分为四种,以下为各个类型的讲解。
2.1 原子更新基本类型
AtomicBoolean:更新的 boolean 值。适用于多线程中状态控制,如销毁或是执行状态。
AtomicInteger:更新的 int 值。常用于资源数量的控制操作,如线程池中资源数量,以此来判断新的任务是否加入线程池中。
AtomicLong:更新的 long 值。
2.2 原子更新数组——更新数组中指定的值
AtomicIntegerArray:更新其元素的 int 数组。
AtomicLongArray:更新其元素的 long 数组。
2.3 原子更新引用类型——更新多