package ThreadLearn;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicIntegerArray;
public class T015_1 {
//jdk1.5开始提供原子类包 Atomic包里一共you 13个原子类
static AtomicInteger ai= new AtomicInteger(1);
//原子更新数组
//AutomicIntegerArray,AutomicLongArray,AutomicReferenceArray
//AutomicIntegerArray常用方法,int addAndGet(int i,int delta) boolean compareAndSet(int i,int except,int update)
static int [] value =new int[]{1,2};
static AtomicIntegerArray aiArray=new AtomicIntegerArray(value);
public static void main(String [] args) {
System.out.println(ai.addAndGet(5));
//以原子的方式将当前值加1,这是返回之前的值
System.out.println(ai.getAndIncrement());
System.out.println(ai.get());
//以原子方式设置为newvalue的值,并返回旧值
System.out.println(ai.getAndSet(8));
System.out.println(ai.get());
//看了automicBoolean源码,就是把Boolean转换为整形,再用compareAndSwapInt进行CAS,原子类其他更新也是如此
aiArray.getAndSet(0, 3);
System.out.println(aiArray.get(0));//快速安全的,相当于复制了一份
}
}
原子更新字段类
•AtomicIntegerFieldUpdater:原子更新整型的字段的更新器。
•AtomicLongFieldUpdater:原子更新长整型字段的更新器。
•AtomicStampedReference:原子更新带有版本号的引用类型。该类将整数值与引用关联起来,可用于原子的更新数据和数据的版本号,可以解决使用CAS进行原子更新时可能出现的ABA问题。
第一步,因为原子更新字段类都是抽象类,每次使用的时候必须使用静态方法AtomicIntegerFieldUpdater.newUpdater创建一个更新器,并且需要设置想要更新的类和属性。第二步,更新类的字段(属性)必须使用public volatile修饰符(private volatile int old)