重磅干货:Java原子操作之CAS原子指令学习

Java原子操作之CAS,CAS(Compare and Swap),即比较并替换,是用于实现多线程同步的原子指令。

1. 无锁的概念

在谈论无锁概念时,总会关联起乐观派与悲观派,对于乐观派而言,他们认为事情总会往好的方向发展,总是认为坏的情况发生的概率特别小,可以无所顾忌地做事,但对于悲观派而言,他们总会认为发展事态如果不及时控制,以后就无法挽回了,即使无法挽回的局面几乎不可能发生。

这两种派系映射到并发编程中,就如同加锁与无锁的策略,即加锁是一种悲观策略,无锁是一种乐观策略,因为对于加锁的并发程序来说,它们总是认为每次访问共享资源时总会发生冲突,因此必须对每一次数据操作实施加锁策略。

而无锁则总是假设对共享资源的访问没有冲突,线程可以不停执行,无需加锁,无需等待,一旦发现冲突,无锁策略则采用一种称为CAS的技术来保证线程执行的安全性,这项CAS技术就是无锁策略实现的关键,下面我们进一步了解CAS技术的奇妙之处。

重磅干货:Java原子操作之CAS原子指令学习

2. 什么是CAS

CAS(Compare and Swap),即比较并替换,是用于实现多线程同步的原子指令。

执行函数:CAS(V,E,N)

其包含3个参数:

· V表示要更新的变量

· E表示预期值

· N表示新值

假定有两个操作A和B,如果从执行A的线程来看,当另一个线程执行B时,要么将B全部执行完,要么完全不执行B,那么A和B对彼此来说是原子的。

实现原子操作可以使用锁,锁机制,满足基本的需求是没有问题的了,但是有的时候我们的需求并非这么简单,我们需要更有效,更加灵活的机制,synchronized关键字是基于阻塞的锁机制,也就是说当一个线程拥有锁的时候,访问同一资源的其它线程需要等待,直到该线程释放锁。

这里会有些问题:首先,如果被阻塞的线程优先级很高很重要怎么办?其次,如果获得锁的线程一直不释放锁怎么办?(这种情况是非常糟糕的)。还有一种情况,如果有大量的线程来竞争资源,那CPU将会花费大量的时间和资源来处理这些竞争,同时,还有可能出现一些例如死锁之类的情况,最后,其实锁机制是一种比较粗糙,粒度比较大的机制,相对于像计数器这样的需求有点儿过于笨重。

实现原子操作还可以使用当前的处理器基本都支持CAS的指令,只不过每个厂家所实现的算法并不一样,每一个CAS操作过程都包含三个运算符:一个内存地址V,一个期望的值A和一个新值B,操作的时候如果这个地址上存放的值等于这个期望的值A,则将地址上的值赋为新值B,否则不做任何操作。

CAS的基本思路就是,如果这个地址上的值和期望的值相等,则给其赋予新值,否则不做任何事儿,但是要返回原值是多少。循环CAS就是在一个循环里不断的做cas操作,直到成功为止。

CAS是怎么实现线程的安全呢?语言层面不做处理,我们将其交给硬件—CPU和内存,利用CPU的多处理能力,实现硬件层面的阻塞,再加上volatile变量的特性即可实现基于原子操作的线程安全。

3. CPU指令对CAS的支持

或许我们可能会有这样的疑问,假设存在多个线程执行CAS操作并且CAS的步骤很多,有没有可能在判断V和E相同后,正要赋值时,切换了线程,更改了值。造成了数据不一致呢?答案是否定的。

因为CAS是一种系统原语,原语属于操作系统用语范畴,是由若干条指令组成的,用于完成某个功能的一个过程,并且原语的执行必须是连续的,在执行过程中不允许被中断,也就是说CAS是一条CPU的原子指令,不会造成所谓的数据不一致问题。

重磅干货:Java原子操作之CAS原子指令学习

4. 悲观锁,乐观锁

说到CAS,不得不提到两个专业词语:悲观锁,乐观锁。我们先来看看什么是悲观锁,什么是乐观锁。

4.1 悲观锁

顾名思义,就是比较悲观的锁,总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁(共享资源每次只给一个线程使用,其它线程阻塞,用完后再把资源转让给其它线程)。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。Java中synchronized和ReentrantLock等独占锁就是悲观锁思想的实现。

4.2 乐观锁

反之,总是假设最好的情况,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号机制和CAS算法实现。乐观锁适用于多读的应用类型,这样可以提高吞吐量,像数据库提供的类似于write_condition机制,其实都是提供的乐观锁。我们今天讲的CAS就是乐观锁。

由于CAS操作属于乐观派,它总认为自己可以成功完成操作,当多个线程同时使用CAS操作一个变量时,只有一个会胜出,并成功更新,其余均会失败,但失败的线程并不会被挂起,仅是被告知失败,并且允许再次尝试,当然也允许失败的线程放弃操作。基于这样的原理,CAS操作即使没有锁,同样知道其他线程对共享资源操作影响,并执行相应的处理措施。同时从这点也可以看出,由于无锁操作中没有锁的存在,因此不可能出现死锁的情况,也就是说无锁操作天生免疫死锁。

5. CAS 的优点

非阻塞的轻量级乐观锁, 通过CPU指令实现, 在资源竞争不激烈的情况下性能高, 相比synchronize重量级悲观锁, synchronize有复杂的加锁, 解锁和唤醒线程操作。

免责声明:文章内容来自互联网,本站仅作为分享,不对其真实性负责,如有侵权等情况,请与本站联系删除。
转载请注明出处:重磅干货:Java原子操作之CAS原子指令学习 https://www.dachanpin.com/a/cyfx/11677.html

(0)
Python教程:列表的排序操作
上一篇 2023-05-12 03:34:32
Java教程:NIO的基本用法
下一篇 2023-05-12 03:35:20

相关推荐

  • 【我奋斗 我幸福】电商为90后小伙插上创业翅膀

      新疆日报讯(通讯员王厚云报道)12月21日,走进库车县齐满镇托库孜托玛村的电子商务服务站,整洁的小店里货物摆放有序,服务站负责人90后小伙吾甫尔·艾合买提正在忙碌着。“自从接触到电子商务,我就知道自己选对了行业,走对了路。”吾甫尔自豪地说。   今年26岁的吾甫尔3年前从伊犁师范学院毕业后,四处打工,但他始终有一个创业的梦想。   2017年,库车县电子…

    创业分享 2023-05-13
    114
  • 吸引更多知名机构落户打造全球创投风投中心

    □青岛日报/青岛观/青报网记者 薛华飞     本报5月7日讯 今天上午,市委副书记、市长孟凡利来到崂山区的全球(青岛)创投风投中心大厦,调研中心建设情况及2019全球(青岛)创投风投大会筹备工作情况。他指出,要深入贯彻落实习近平总书记“办好一次会,搞活一座城”重要指示要求,紧紧抓住举办2019全球…

    创业分享 2023-05-13
    119
  • 骑士团主办的“寒冬微芒”创业大赛总决赛圆满成功

    骑士团主办的“寒冬微芒”创业大赛总决赛圆满成功 人加智能的李嘉俊代表北大孵化器,做了关于“参加创业比赛提升创业心智”的主题演讲,并坦言参与创业大赛,可以帮助创业者“提升创业心智,打磨商业模式”。 此次决赛入围的有6个项目,分别是:儿童家居消费升级项目“宝贝成长空间改造”、英语培训SAAS项目“一块岩石”、演出艺人服务项目“因趣斯汀”、C2M校园电商项目“桔子…

    2023-05-22
    122
  • 除了合伙人和投资人 创业成功还有这些砝码!

    原标题:除了合伙人和投资人 创业成功还有这些砝码! 在很多创业者眼中,团队和资金是创业能否成功的决定性要素,找合伙人和投资人也因此成为创业者投注精力最多的事情。但事实上,创业是一个复杂的系统工程,出色的合伙人和成功的投资人只是创业成功的必要条件中的一部分。“合伙人和投资人之外,创业者还需要哪些要素给成功加码?”记者本周带着这一问题走访了众多创业者,让他们分享…

    创业分享 2023-05-27
    169
  • 邵东县聚焦“富民”关键大力推进就业创业 中国劳动保障新闻网

      实施更加积极的优惠政策,分别设立了产业引导基金20亿元、创投基金4亿元、过桥担保资金1亿元、工业发展资金1亿元。2018年,发放创业担保贷款153笔,发放贷款金额1710万元,不断加大信贷支持,为大众创新创业最大限度“松绑”。   “在技能培训班上不仅有老师面对面授课,而且学员可以课下互动交流,大家的技能水平和兴趣都得到提高,已经有企业和农村合作社直接与…

    创业分享 2023-05-13
    136

发表回复

登录后才能评论

联系我们

在线咨询: QQ交谈

邮件:362039258@qq.com

工作时间:周一至周五,9:30-16:30,节假日休息