为什么会有偏向锁、轻量级锁和重量级锁?

并发锁总共有4种状态:无锁状态、偏向锁状态、轻量级锁状态和重量级锁状态,每种状态在并发竞争情况下需要消耗的资源由低到高,性能由高到低。重量级锁需要通过操作系统在用户态与核心态之间切换,就像它的名字是一个重量级操作,这也是synchronized效率不高的原因,JDK1.6对synchronized进行了优化,引入了偏向锁与轻量级锁,提高了性能降低了资源消耗。

什么是偏向锁?

通过对大量数据的分析可以发现,大多数情况下锁竞争是不会发生的,往往是一个线程多次获得同一个锁,于是引入了偏向锁,偏向锁不会被刻意的释放,如果没有竞争,线程再次请求锁时可以直接获得锁。

偏向锁的获取

我们先来回顾一下偏向锁对象头的存储结构

  1. 首先检查对象头Mark Word中锁标记是否是偏向锁
  2. 检查对象头中记录的线程ID是否是当前线程的ID,如果是说明当前线程已经获得过锁,当前线程将再次获得锁,可以执行同步代码
  3. 如果对象头中的线程ID不是当前线程的ID,则通过CAS操作替换成当前线程的ID,如果替换成功意味着当前线程获得了锁,可以执行同步代码
  4. 如果步骤3的CAS操作失败,则意味着已经有别的线程获得了锁,针对这个锁出现了竞争,当已经获得了锁的线程到达全局安全点后(没有字节码执行)会被挂起,偏向锁膨胀为轻量级锁,被挂起的线程被唤醒,线程将按照轻量级锁的机制竞争锁

通过以上偏向锁的获得过程可以发现,偏向锁没有释放的步骤,它的加锁、解锁不需要消耗额外的资源;一旦偏向锁出现了竞争,它就会膨胀成轻量级锁,所以在锁竞争比较多的情况下它会额外的消耗资源做锁的膨胀。

什么是轻量级锁?

轻量级锁的性能介于偏向锁与重量级锁之间,在存在锁竞争的情况下,不需要让线程在阻塞与唤醒状态间切换,它的对象头存储结构如下:

除了对象头,轻量级锁还有一个相关的存储结构Monitor Record,它是JVM在栈中开辟出的一块空间,里面会保存获得锁的线程信息,而对象头中记录的锁指针就指向这个Monitor Record。

轻量级锁的获取

  1. JVM在执行同步代码块前,会在栈中开辟一块空间存储锁记录Monitor Record,并将对象头中的Mark Word复制到锁记录中,称为Displaced Mark Word。
  2. 线程通过CAS操作尝试将Mark Word指向锁记录,如果成功意味着线程获得了锁,Monitor Record中会有一个字段Owner记录获得锁的线程信息
  3. 如果步骤2中的CAS操作失败,则线程进入自旋等待(默认10次),如果自旋成功,则线程获得了锁可以执行同步代码,如果自旋失败,这个锁会膨胀成重量级锁
  4. 线程执行完成后,将通过CAS操作将Monitor Record中记录的Displaced Mark Word替换回对象头中的Mark Word,如果操作成功则锁被释放,如果操作失败,则意味着存在锁竞争,这个锁将膨胀成重量级锁

由以上轻量级锁的获取步骤可以看出,竞争锁的线程如果竞争失败不会进入阻塞状态,所以不会发生线程在用户态与核心态的切换,资源消耗比重量级锁少,但是竞争失败的线程会进入自旋状态,这又白白浪费了CPU计算资源。

什么是重量级锁?

重量级锁在JVM中有一个监视器(Monitor),保持了两个队列:锁竞争队列和信号阻塞队列,一个实现线程互斥,另一个实现线程同步。重量级锁在底层是靠操作系统的Mutex Lock实现的,线程在阻塞和唤醒状态间切换需要操作系统将线程在用户态与核心态之间转换,成本很高,所以最早的synchronized效率不高。

偏向锁、轻量级锁和重量级锁对比

锁类型 优点 缺点 适用场景
偏向锁 加锁、解锁不需要额外资源消耗,效率较高 如果线程间存在锁竞争,会带来额外的解锁消耗 适用只有一个线程访问同步块的情景
轻量级锁 竞争的线程不会阻塞,提高了程序响应速度 如果获取锁失败,会进入自旋消耗cpu 针对锁占用时间短,对响应时间比较敏感的情况
重量级锁 线程竞争不使用自旋,不消耗cpu 线程会被阻塞,影响响应时间 锁占用时间较长,对吞吐量要求较高

偏向锁、轻量级锁和重量级锁相关推荐

  1. 12.synchronized的锁重入、锁消除、锁升级原理?无锁、偏向锁、轻量级锁、自旋、重量级锁

    小陈:呼叫老王...... 老王:来了来了,小陈你准备好了吗?今天我们来讲synchronized的锁重入.锁优化.和锁升级的原理 小陈:早就准备好了,我现在都等不及了 老王:那就好,那我们废话不多说 ...

  2. 简单理解重量级锁、轻量级锁、偏向锁

    全文使用synchronized来说明. synchronized给对象上锁,先上偏向锁,在上轻量级锁,最后上重量级锁.上什么锁,是gvm根据竞争程度自行变换的. 重量级锁 计算机操作系统本有Moni ...

  3. java多线程之锁 -- 偏向锁、轻量级锁、自旋锁、重量级锁

    转载至:https://blog.csdn.net/zqz_zqz/article/details/70233767 之前做过一个测试,详情见这篇文章<多线程 +1操作的几种实现方式,及效率对比 ...

  4. Java如何避免重量级锁,Java 中锁是如何一步步膨胀的(偏向锁、轻量级锁、重量级锁)...

    文章目录 重量级锁(Mutex Lock) 偏向锁(比较 ThreadID) 偏向锁获取过程 偏向锁的释放 轻量级锁(自旋) 轻量级锁的加锁过程 轻量级锁的释放 总结 重量级锁(Mutex Lock) ...

  5. 2021-06-01 深入分析偏向锁、轻量级锁和重量级锁

    目录 一 重量级锁 1.1 什么是重量级锁?重量级是怎么体现的? 1.2 重量级锁的监视器工作流程 1.2.1 线程竞争锁 1.2.2 线程锁竞争成功 1.2.3 线程竞争锁失败 1.2.4 运行中的 ...

  6. 操作系统锁的实现方法有哪几种_java 偏向锁、轻量级锁及重量级锁synchronized原理...

    Java对象头与Monitor java对象头是实现synchronized的锁对象的基础,synchronized使用的锁对象是存储在Java对象头里的. 对象头包含两部分:Mark Word 和 ...

  7. 轻量级锁_一句话撸完重量级锁、自旋锁、轻量级锁、偏向锁、悲观、乐观锁等各种锁 不看后悔系列...

    重量级锁?自旋锁?自适应自旋锁?轻量级锁?偏向锁?悲观锁?乐观锁?执行一个方法咋这么辛苦,到处都是锁. 今天这篇文章,给大家普及下这些锁究竟是啥,他们的由来,他们之间有啥关系,有啥区别. 重量级锁 如 ...

  8. 轻量级锁_Java高级架构师-Java锁的升级策略 偏向锁 轻量级锁 重量级锁

    欢迎关注头条号:Java小野猫 这三种锁是指锁的状态,并且是专门针对Synchronized关键字.JDK 1.6 为了减少"重量级锁"的性能消耗,引入了"偏向锁&quo ...

  9. 锁升级过程(偏向锁/轻量级锁/重量级锁)

    锁的前置知识 如果想要透彻的理解java锁的来龙去脉,需要先了解锁的基础知识:锁的类型.java线程阻塞的代价.Markword. 锁的类型 锁从宏观上分类,分为悲观锁与乐观锁. 乐观锁 乐观锁是一种 ...

  10. JVM内部锁升级过程(偏向锁,轻量级锁,重量级锁)

    目录 对象在内存中是如何布局的 如何查看对象在内存中的布局 markword数据结构 加锁后发生了什么 偏向锁 什么是偏向锁 偏向锁定时hashCode 哪去了? 为什么需要偏向锁 为什么从JDK15 ...

最新文章

  1. 【ACM】CODE[VS] 1215 (DFS)
  2. 低代码、无代码?深度解读硅谷新趋势
  3. OpenStack Swift源码安装
  4. C语言笔记(关键字)
  5. 利用子网掩码划分子网
  6. mysql抽屉图标_React Native自定义组件实现抽屉菜单控件效果
  7. 给我一个及时的问候——XMPP
  8. SQL Server补丁版本的检查
  9. HTML用户登录页面里面login.js代码
  10. 不是生活所迫,谁特么想努力!
  11. 3.5 Zend_Db_Table_Rowset
  12. 循环问题2012蓝桥杯省赛第四题 奇怪的比赛(暴力解决)
  13. php store快捷键设置,mac 下 phpstorm 快捷键整理
  14. 新冠能否开启物联网发展的大门
  15. Rest-assured框架详解
  16. html去除背景颜色怎么设置,word文档背景颜色怎么去掉,文档背景颜色怎么去掉
  17. 腾讯、淘宝的架构大数据你有了解么?大数据技术及算法为你解析
  18. python excel提取 替换_python代替excel的常用操作
  19. linux ops 一些函数简介
  20. CMS垃圾回收器和G1垃圾回收器区别

热门文章

  1. C语言算法——实现冒泡排序
  2. 报表系统软件有哪些_报表系统软件功能
  3. 通用高效分页存储过程
  4. ios9与ios8的区别
  5. 【第二章 | 进程的描述与控制】《操作系统 慕课版》课后答案 + 复习
  6. 什么是 BI?和报表有什么关系?有了 BI 还要做报表吗?
  7. 一个被加入下载QQ盗号木马Trojan.PSW.QQPass.rie代码的网站
  8. python求幂集_求幂集的算法 - Sethylar的个人页面 - OSCHINA - 中文开源技术交流社区...
  9. 转臂式多芯自清洗过滤器
  10. Linux 基础 入门