CAS与synchronized的使用情景

Posted 四猿外

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CAS与synchronized的使用情景相关的知识,希望对你有一定的参考价值。

简单的来说CAS适用于写比较少的情况下(多读场景,冲突一般较少)
synchronized适用于写比较多的情况下(多写场景,冲突一般较多)

  • 1.对于资源竞争较少(线程冲突较轻)的情况,使用synchronized同步锁进行线程阻塞和唤醒切换以及用户态内核态间的切换操作额外浪费消耗cpu资源;而CAS基于硬件实现,不需要进入内核,不需要切换线程,操作自旋几率较少,因此可以获得更高的性能。
  • 2.对于资源竞争严重(线程冲突严重)的情况,CAS自旋的概率会比较大,从而浪费更多的CPU资源,效率低于synchronized。

补充: Java并发编程这个领域中synchronized关键字一直都是元老级的角色,很久之前很多人都会称它为 “重量级锁” 。但是,在JavaSE 1.6之后进行了主要包括为了减少获得锁和释放锁带来的性能消耗而引入的 偏向锁 和 轻量级锁 以及其它各种优化之后变得在某些情况下并不是那么重了。synchronized的底层实现主要依靠 Lock-Free 的队列,基本思路是 自旋后阻塞,竞争切换后继续竞争锁,稍微牺牲了公平性,但获得了高吞吐量。在线程冲突较少的情况下,可以获得和CAS类似的性能;而线程冲突严重的情况下,性能远高于CAS。

以上是关于CAS与synchronized的使用情景的主要内容,如果未能解决你的问题,请参考以下文章

CAS自旋锁与synchronized关键字的使用与区别

[多线程进阶]CAS与Synchronized基本原理

Java并发- synchronized与CAS

并发编程CAS与synchronized

Java并发编程系列- 原子操作与CAS

并发与多线程——同步与互斥