1、定义: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等