CAS

写在前面

昨天电话面试,面试官问了我一个关于CAS算法的问题,结果我回答的比较模糊,只是回答的CAS一部分(比较和交换),后来通过自己的录音去听了一下自己的回答,真的无法在听下去了,其实以前使用并发包中原子类时有了解过CAS算法,但是没有特别深入,有句话怎么说,该欠的总是要还的(我一口老血吐了出来),希望这篇文章能为准备面试或者需要了解CAS能带一个入门。

CAS算法

CAS算法:即比较并替换,是一种实现并发算法时常用到的技术,JAVA并发包中的很多类都使用了CAS技术。CAS需要有3个操作数:内存值V,旧的预期值A,即将要更新的目标值。(是否感觉像数据库中的乐观锁那?)

数据库中乐观锁实现:数据库乐观锁设计3个操作数,数据库版本号V,线程所带的版本号T,即将要更新新的版本号N,当前仅当V == T的时候才更新N(数据库一般不会去重试,只会判断,成功之后才会更新),这不就是CAS算法吗?

CAS缺点

CAS虽然很高效的解决了原子操作问题,但是CAS仍然存在三个问题:

  1. 循环时间长开销很大
  2. 只能保证一个共享变量的原子操作
  3. ABA问题

循环时间长开销很大

如果CAS时间一直不成功,可能会给CPU带来很大的开销

只能保证一个共享变量的原子操作

但对一个共享变量执行操作时,我门可以使用循环CAS的方式来保证原子操作,但是对多个共享变量操作时,就无法保证操作的原子性,这个时候就可以使用锁来保证原子性

什么是ABA问题?

比如内存地址V初次读取的值为A,那么在准备赋值的时候检查到的值为A,我们能保证这个值没有被其他线程所改变了吗?

假如某段时间内存中的值被修改了B,然后又被修改成了A,那么CAS就会误认为这个值就没有被修改过。这个漏洞成为ABA问题

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值