CAS原理

什么是CAS compare and swap——比较并替换

  • 并发
  • 我认为V的值应该是A,如果是的那我就把它改成B,如果不是A(说明被修改过了),那我就不修改了,避免多人同时修改导致出错。
  • CAS有三个操作数:内存值V、预期值A、要修改的值B,当且仅当预期值A和内存值V相同时,才将内存值修改为B,否则什么都不做。最后返回现在的V值。

应用场景

  • 乐观锁
  • 并发容器:ConcurrentHashMap
  • 原子类

CAS的缺点

  • ABA问题:CAS只会对比现在的值和原来的值是否相同,而不会判断是否发生了改变,这样就会认为没有发生过变化,会导致一些逻辑无法实现。
  • 解决办法:沿用数据库的方式,通过加上一个版本号来解决。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值