cas自旋锁

cas的全称为compare and swap,比较和替换,是一种无锁状态的锁。该锁的实现机制是,当我们需要改一个对象的值的时候,我们会先获取到该值并通过算法生成一个新的值,然后我们去查看当前变量的新值(重新获取一次变量的值)与期望值是否相等(期望值是我们期望变量没有发生改变),如果相等,则不能将新值赋值给此变量,并重新执行算法,重新判断。如果未发生改变则将新值赋值给变量。
如下图所示(新值N是第二次读取变量的值,E为第一次读取变量的值,判断两个值是否发生变化从而判断变量是否被其他线程修改过,如果值发生变化,则证明变量被其他线程修改了,如果没有则证明没有。)
因为cas是通过CPU的原语实现的,所以不会存在再cas运行过程中有其他进程对变量进行操作。
在这里插入图片描述
OCK CMPXCHG
一、交换指令:CMPXCHG、XCHG
自旋锁实现的底层指令是lock cmpxchg,
1) CPMXCHG
• 用于比较并交换操作数,CPU对CAS的原语支持
• 非原子性,最早用于单核CPU
2)XCHG
• 用于交换两个操作数
• 具备原子性,CPU会自动加LOCK前缀
二、 LOCK前缀

  1. 作用
    CPU保证被其修饰的指令的原子性。当执行lock后面的指令的时候其他线程不能对当前变量进行修改。
  2. 实现方式(详情参见:多处理器下的数据一致性)
    1)依赖内存有序模型,来保证读取指令有序;
    2)通过总线锁或缓存一致性,保证被修饰指令操作的数据一致性:
    • 当访问的数据在系统内存时,通过在总线锁实现原子性;
    • 当访问的数据在处理器的缓存时,通过缓存一致性协议实现原子性;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值