一、什么是 CAS?
CAS 是 compare and swap(比较并交换)的首字母缩写,它的操作是抱着乐观的态度进行的,属于乐观锁机制。它的原理是:如果多个线程 CAS 更新同一个变量的话,那么只有一个线程可以成功,其他线程则全部失败,但失败的线程不会被挂起,仅是被告知失败。失败的线程可以再次尝试更新,当然也允许线程放弃操作。
二、CAS 有什么缺点?
1. 如果循环时间长,则会导致 CPU 开销很大。
2.CAS 只能保证一个共享变量的原子操作(如果多个共享变量需要用锁去解决)
3. 可能会导致 ABA 问题
三、什么是 ABA 问题?
ABA 问题就是,当两个线程 one 和 two 同时从内存位置 V 中取出变量 A,这时线程 two 将变量 A 修改为 B,然后又修改成 A,然后变量 A 虽然中间被修改过,但变量前后不变。然而线程 one 读取到的变量 A 没有发生变化,则认为没有被修改过,这就产生了 ABA 问题,导致线程不安全。