CAS

1.CAS做了什么?

CAS有三个操作数:内存值V,旧的预期值A,需要修改的新值B
CAS涉及两个步骤:

  • 1.compare:比较内存值是否与预期值A相等。
  • 2.set:如果内存值与预期值A相等,set值为B。
    虽然这是两步,但是CAS保证了这两步操作的原子性,因此可以将上面两步视为一个原子操作。

2.处理器如何实现原子操作?

1.使用总线锁保证原子性
总线锁就是使用处理器提供的一个LOCK#信号,当一个处理器在总线上输出此信号时,其他处理器的请求将被阻塞住,那么该处理器可以独占使用共享内存。

缺点: 效率低
原因: 总线锁把CPU和内存之间的通信锁住了,导致锁定期间其他处理器不能操作其他内存地址的数据,所以总线锁定的开销比较大。

2.使用缓存锁保证原子性
缓存锁就是如果缓存在处理器缓存行中内存区域在LOCK操作期间被锁定,那么当它执行锁操作会写内存时,处理器不在总线上声言LOCK#信号,而是修改内部的内存地址,并允许它的缓存一致性机制来保证操作的原子性,因为缓存一致性机制会组织同时修改由两个以上处理器缓存的内存区域数据,当其他处理器回写已被锁定的缓存行的数据时,会使缓存行无效。

3.CAS缺点

  • 循环时间长开销很大
    如果CAS失败,会一直进行尝试。如果CAS长时间一直不成功,可能会给CPU带来很大的开销。
  • 只能保证一个共享变量的原子操作
  • ABA问题

4.ABA问题

如果从内存地址V取值,原来值为A,修改为B,之后又将值修改为A,CAS会认为该值从来没变过。
解决思路:加版本号。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 粉底白衫拂拭镜 花烛良结拜玉堂 岁月渐浓胭脂色 切切琴箫无声常 柳泊烟鸣江畔盼 坍圮烽烟巍茫盳 他们呀 一起把蜜儿...
    叶树材阅读 344评论 0 1
  • 前段时间收到一个快递,里面有地瓜干、饼干之类的零食,是姐姐买的。口味并无特别之处,但是其中的一篇文案引起了我的注意...
    自律是自由阅读 658评论 0 48
  • “总会有一个人的出现、他会打破你的原则、改变你的习惯、成为你的例外。” 我们总会把自己的生活放在各种条条框框里、找...
    鹿角女王阅读 6,957评论 0 3
  • 迁移Linux主机注意事项: 1,注意主机之间安装软件版本问题;2,根据主机所提供服务,细化迁移的文件;3,查看主...
    Zhang21阅读 345评论 0 0