并发编程--原子变量和CAS

什么是原子变量?
在多线程并发当种,JAVA对与数据变量的修改采用了synchronized原子性,原子变量又是另一种能保证原子性。使用原子变量能够比使用synchronized实现原子性提高性能,synchronized减少获取锁,等待锁的时间,上下文切换时间。
原子变量的原理
CAS在有两者说法一种是compareAndSet,另一种说法是compareAndSwap,我这边做了调查发现实际上compareAndSet的底层调用就是unsafe的compareAndSwap xxxx方法,所以说严格讲CAS代表意思是compareAndSet。

public final boolean compareAndSet(int expect, int update) {
    return unsafe.compareAndSwapInt(this, valueOffset, expect, update);
}

CAS含义:使用当前值和except值进行比较,如果相等就更新为update值,返回true,否则不更新返回false。因为它采用的是比较更新,和synchronized相比,没有诸塞,没有上下文切换,所以乐观非阻塞性能高于悲观阻塞式方式。
CAS是JAVA并发包的基础,基于它实现了高效,乐观,非阻塞式算法和数据结构,它是并发包中锁,同步工具和各种容器的基础。

你可能感兴趣的:(并发编程--原子变量和CAS)