1、定义:cas可以理解为读取原值,在更新的时候在看一下原值是否已经改变了,改变了则更新失败,没有改变则更新,看下图

CAS的初步理解_CAS

2、产生的问题:

  • ABA问题:可以理解为你跟你女朋友分手了,然后你女朋友又结交n个男朋友,最后又和你符合   

              正常理解:就是多线程情况下,假设有AB两个线程,A修改成0,此时A还没提交B就过来修改成原值,然后最后输出就是B

  • 怎么解决:
    • 加版本号version
    • 加时间戳
  •     忙循环,CPU消耗大

3、补充

  • 乐观锁:比喻为你出门相信别人不来偷你家东西,不关门
  • 悲观锁:比喻为你出门不相信别人不来偷你家东西,在门上加个锁。

4、cas的CPU原语(底层实现):用的是unsafe方法,可以理解为自己为自己留后门

5、cas的更深的本质:lock cmpxchg指令

6、cas的运用:原子类,synchronized,reentrantLock等