CAS原理

CAS

1 为什么要写CAS

有时操作者不希望让操作系统那么“悲观”,每次都使用同步原语对共享资源进行资源锁定,而是希望让线程反复“乐观”的尝试获取共享资源,如果空闲那么是用,如果被占用,则继续尝试。CAS就这样应运而生了。

2 实现原理

2.1 实现

资源Z设置了一个值假设叫Zp,Zp为0代表资源空闲,1代表资源被占用。A,B两个线程发现Zp为0,则都去争抢这个资源,A运气好抢到了这个资源,将Zp改为1,B也不会放弃,会不断回来看看Zp变为0了没。在A获得时间片时,它将oldValue(读到的资源对象的状态值)的状态值进行compare,发现如果一致,将状态值swap为newValue(将资源对象更改后的值)。B在compare阶段发现不一致则放弃swap操作。但在实际中B会自旋等待。不断尝试cas操作。

2.2 注意点

CAS操作必须是原子的,不然会出现A,B同时改Zp,都以为对方没有抢到锁的情况。对此,不同架构的CPU都提供了指令级别的CAS操作。如x86下通过cmpxchg支持CAS,ARM下通过LL/SC支持CAS。至此我们得到了出了mutex(悲观)外,另外一种无锁的同步机制(乐观)。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值