该操作保证了数据的安全性、可靠性
涉及参数:
V:内存中变量的值
A:原内存位置中变量的值
B:更新的值
实现过程:数据变更,首先会把主内存V的值与A的值进行比较,如果这两个值相等,则表示之前没有线程对其修改,可以执行更新操作,把待更新的值E存到内存中覆盖V的值,完成更新操作。如果这两个值不相等,则表示有并发的线程对其进行了修改,此次更新数据失败。重新获取内存中值再次进行以上的过程,直到修改成功。
存在问题
1、ABA问题 2、循环次数过多,内存开销大 3、只能保证一个变量的原子操作
ABA问题:一个变量的值为A,被一个线程修改之后变成了B,之后又被改成了A。一个线程在这个线程进行CAS比较的途中,将内存位置的值已经进行了操作,但是操作结果又将内存位置的值改为了预期原值,这个时候这个线程在比较的时候会发现内存位置和预期原值是相等的所以进行了替换操作,事实上另外一个线程已经对这个内存位置的值进行了操作,但是当前线程并不能发现这个问题
解决该问题:增加版本号如:A1-->B1-->A2