原子操作 CAS
什么是原子操作
利用现代处理器都支持CAS指令,循环执行CAS指令,直至成功。指令级别的保证原子操作。
CAS的原理
内存地址 V 期望值 A 新值 B
当地址V上的值等于A时,就把B赋值给V,若不等于,就不做任何操作,或一直循环。
CAS的问题:
1、ABA问题
内存地址上的值变化 A ->B -> A
可以加版本号解决。
则值的变化就为 A1.0->B1.1->A1.2
2、开销问题
CAS指令执行不成功,则一直循环执行,对CPU的 用一直不释放。
3、只能保证一个共享变量的原子操作
当多个共享变量需要保证原子操作时,可以封装为一个对象,针对对象保证原子操作
JDK中相关原子操作类的使用
1、更新基本类型类:
AtomicBoolean,AtomicInteger,AtomicLong, AtomicReference
2、更新数组类:AtomicIntegerArray,AtomicLongArray,AtomicReferenceArray
3、更新引用类型:AtomicReference,AtomicMarkableReference,AtomicStampedReference
4、原子更新字段类: AtomicReferenceFieldUpdater,AtomicIntegerFieldUpdater,AtomicLongFieldUpdater