synchronized底层原理 以及 公平锁和非公平锁的基本概念

news2025/1/16 17:55:07

一、公平锁和非公平锁的基本概念

公平锁
简单讲就是当一个锁被释放的时候会执行唤醒,此时等待中的其他线程取排在最前面的线程获取被释放的锁并进入运行态。

非公平锁
同样的当一个锁释放时,其他等待的线程并不需要排队,谁刚好来了谁就可以先获得锁进入运行状态。

二、synchronized 底层原理

首先 synchronized 是通过JVM内置的监视器 Monitor 完成的。

例如:
我们在一个类文件写了一个最简单的synchronized ,然后编译成 class 文件

我们可以在命令行使用 javap -c XxxxxxxXxx.class 来完成对该文件的反编译过程
javap 为java 自带的反编译,参数大致有下面这些

	-help 帮助
	-l 输出行和变量的表
	-public 只输出public方法和域
	-protected 只输出public和protected类和成员
	-package 只输出包,public和protected类和成员,这是默认的
	-p -private 输出所有类和成员
	-s 输出内部类型签名
	-c 输出分解后的代码,例如,类中每一个方法内,包含java字节码的指令,
	-verbose 输出栈大小,方法参数的个数
	-constants 输出静态final常量

此时可以从黑框中看到有这些输出
在这里插入图片描述
所以可以看得出 monitor 参与了synchronized的实现。

接下来就是整体的流程
synchronized 是 Java中用于实现线程同步的关键字,它可以用于修饰方法或代码块。synchronized的底层实现原理主要涉及到对象头、monitor和锁升级等概念。

在Java对象的内存布局中,每个对象都有一个对象头,对象头中包含了一些元数据信息,其中就包括了用于实现synchronized的monitor。
当一个线程进入synchronized修饰的方法或代码块时,它会尝试获取对象的monitor。

当一个线程获取到monitor后,它就可以执行synchronized修饰的代码,其他线程则需要等待。当线程执行完synchronized代码后,会释放monitor,让其他线程有机会获取到monitor并执行相应的代码。

synchronized关键字的底层实现主要有两种方式:
偏向锁和重量级锁。偏向锁是指当一个线程获取到monitor后,如果没有其他线程竞争,那么下次该线程再次进入同步块时就无需再次竞争,直接执行即可。这种情况下,锁的开销非常小。而重量级锁则是指当多个线程竞争同一个monitor时,会涉及到线程的阻塞和唤醒等操作,开销相对较大。

锁的升级是指在多个线程竞争同一个monitor时,锁的状态会从偏向锁升级为轻量级锁,再升级为重量级锁。这是为了在竞争激烈的情况下提高并发性能。

详细一点的锁升级过程
在Java对象头中,有一个用于存储锁信息的字段,称为Mark Word。Mark Word中的一部分用于存储对象的HashCode,另一部分用于存储锁的状态。当一个线程进入synchronized修饰的方法或代码块时,它会尝试获取对象的锁。

如果对象的锁状态为无锁状态(标记为01),则该线程可以获取到锁,并将锁状态标记为偏向锁状态(标记为01)。此时,线程会将自己的Thread ID记录在Mark Word中,并继续执行同步代码。

如果对象的锁状态为偏向锁状态,并且记录的Thread ID与当前线程的Thread ID相同,则该线程可以直接获取到锁,并继续执行同步代码。

如果对象的锁状态为偏向锁状态,但记录的Thread ID与当前线程的Thread ID不同,则需要撤销偏向锁,并升级为轻量级锁状态。升级为轻量级锁状态时,会在当前线程的栈帧中创建一个Lock Record,并将对象头中的Mark Word指向该Lock Record。然后,线程会尝试使用CAS(Compare and Swap)操作将对象头中的Mark Word替换为指向Lock Record的指针。如果CAS成功,表示该线程获取到了锁,并继续执行同步代码。

如果对象的锁状态为轻量级锁状态,表示有多个线程竞争该锁。当一个线程尝试获取轻量级锁时,会使用CAS操作将对象头中的Mark Word替换为指向Lock Record的指针。如果CAS成功,表示该线程获取到了锁,并继续执行同步代码。如果失败,表示有其他线程竞争锁,此时会进一步升级为重量级锁状态。

重量级锁是通过操作系统的互斥量(Mutex)来实现的,它会将竞争锁的线程阻塞,并将其放入等待队列中。当持有锁的线程释放锁时,会唤醒等待队列中的一个线程来获取锁。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1519100.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LeetCode 80.删除有序数组中的重复项 II

目录标题 删除有序数组中的重复项 II题目解题思路实现代码代码讲解总结删除有序数组中的重复项 II 题目 解题思路 慢指针指向满足条件的数字的末尾,快指针遍历原数组。 并且用一个变量记录当前末尾数字出现了几次,防止超过两次。最后返回维护慢指针的结果+1即可。 实现代…

【数据可视化】Echarts最常用图表

个人主页 : zxctscl 如有转载请先通知 文章目录 1. 前言2. 准备工作3. 柱状图3.1 绘制堆积柱状图3.2 绘制标准条形图3.3 绘制瀑布图 4. 折线图4.1 绘制堆积面积图和堆积折线图4.2 绘制阶梯图 5. 饼图5.1 绘制标准饼图5.2 绘制圆环图5.2 绘制嵌套饼图5.3 绘制南丁格尔…

文件操作与IO流

文章目录 File文件操作类IO流原理及流的分类节点流FileInputStreamFileOutputStreamFileReaderFileWriter 处理流BufferedReaderBufferedWriterBufferedInputStreamBufferedOutputStreamObjectInputStreamObjectOutputStreamPrintStreamPrintWriter 标准输入输出流 Properties …

【声速、频率、波长、波数、波矢】

【声速、频率、波长、波数、波矢】 在声学中,声速(Speed of Sound)、频率(Frequency)、波长(Wavelength)、波数(Wave Number)和波矢(Wave Vector)是描述声波传播特性的重要物理量。它们之间的关系如下: 声速(Speed of Sound): 表示声波在介质中传播的速度,通常…

Vue 运行报错 Error: Cannot find module ‘semver‘

文章目录 项目场景:问题描述解决方案:注意: 项目场景: 提示:这里简述项目相关背景: 运行 Vue 后遇到一个报错: 我的项目是WebStorm 运行的,不通过命令运行,我奇怪的是…

用网格大师网络重划分时,坐标原点按照XML文件原点填写,导出的瓦块文件命名不对,坐标原点该怎么填写

瓦块名称和原来不一致的原因是瓦块原点这里设置的不对,要和重建设置的瓦块原点保持一致。 网格大师是一款能够解决实景三维模型空间参考、原点、瓦块大小不统一,重叠区域处理问题的工具“百宝箱”,集格式转换、坐标转换、轻量化、瓦片重划分…

探秘Kafka位移在消息旅程中的神奇

欢迎来到我的博客,代码的世界里,每一行都是一个故事 探秘Kafka位移在消息旅程中的神奇 前言什么是消费者位移消费者位移的定义和作用:消费者位移对于消息传递的一致性至关重要的原因: 位移的存储方式位移信息的存储方式&#xff1…

非常实用的区间预测!基于QR-BiGRU的时间序列分位数区间预测程序,电池寿命、轴承寿命、负荷预测、光伏、风速、电价、碳价预测

适用平台:Matlab2022版及以上 本程序参考中文EI期刊《电工技术学报》2024年1月30日网络首发文献:《基于QR-BiGRU神经网络与区间抗差增广状态估计的线路参数区间追踪估计》,提出基于QR-BiGRU双向门控循环单元网络的时间序列分位数区间预测程序…

解读 PICO 全新无灯环手柄背后的技术突破

从上世纪70年代的雅达利游戏机开始到后来的PS,Xbox和Switch等,按钮式控制器一直是团队输入的主要方式,并将继续在相当长的时间里继续作为重要的交互方式。这种控制器同样在新兴的XR系统中扮演着关键的角色,通过熟悉的按钮布局和物…

Scala--01--简介、环境搭建

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 1. Scala简介1.1 Scala是什么?官网: [https://scala-lang.org/](https://scala-lang.org/)官方文档: [https://docs.scala-lang.…

Unity中的网格创建和曲线变形

Unity中的网格创建和曲线变形 3D贝塞尔曲线变形贝塞尔曲线基础线性公式二次方公式三次方公式 Unity 实现3D贝塞尔曲线变形准备工作脚本概述变量定义 变量解析函数解析 获取所有子节点GetAllChildren 获取所有子节点UpdateBezierBend 控制点更新CalculateBezier Bezier 曲线公式…

解锁基于LLMS的咒语:通过上下文学习重新思考对齐

一、写作动机: 最近的一项研究,LIMA,表明仅使用1K个示例进行SFT也可以实现显著的对齐性能,这表明对齐微调的效果可能是“表面的”。(知识和推理能力来源于预训练,而不是必须通过对齐微调获得的。&#xff…

掌握未来数据管理:Tidb数据库学习网站全攻略!

介绍:TiDB是一个开源的分布式关系型数据库,由PingCAP公司设计和研发。以下是对TiDB的详细介绍: HTAP支持:TiDB能够同时处理在线事务处理(OLTP)和在线分析处理(OLAP),这使…

50、东北大学、阿尔伯塔大学:Hi-GCN从2个层次角度进行图学习,用来诊断脑部疾病[你这和MVS-GCN套娃呢?]

本文由东北大学医学图像智能计算教育部重点实验室&#xff0c;加拿大阿尔伯塔大学于2020年10.24日发表于<Computers in Biology and Medicine> JCR\IF: Q1\7.7 Abstract&#xff1a; 目的:近年来&#xff0c;脑连接网络已被用于神经系统疾病的分类&#xff0c;如自闭症…

数据仓库的设计开发应用(二)

目录 四、数据仓库的设计&#xff08;一&#xff09;需求分析&#xff08;二&#xff09;概念设计&#xff08;三&#xff09;逻辑设计&#xff08;四&#xff09;物理设计 四、数据仓库的设计 数据仓库的设计包括需求分析、概念设计、逻辑设计和物理设计四个阶段&#xff0c;其…

计算机毕业设计-基于大数据分析的服装定制网的设计与实现

概要 人民的日常生活离不开“衣食住行”&#xff0c;四者之中“食住行”发展迅猛&#xff0c;突飞猛进的发展推动了产业的升级更新。而与之形成鲜明对比的是&#xff0c;服装行业作为传统古老的行业&#xff0c;因为产业结构特征、个性化需求等问题&#xff0c;难以出现推动行业…

算法第二十七天-猜数字游戏

猜数字游戏 题目要求 解体思路 有多少位属于数字和确切位置都猜对了&#xff1a;统计 s e c r e t [ i ] g u e s s [ i ] secret[i]guess[i] secret[i]guess[i]的个数。 有多少位属于数字猜对了但是位置不对&#xff1a;用两个数组&#xff08;哈希表&#xff09;分别统计…

C#实现哈希查找算法​

C#实现哈希查找算法 下面是一个简单的C#代码示例&#xff0c;实现了哈希查找算法&#xff1a; using System; using System.Collections.Generic;class HashSearch {// 哈希查找函数static int HashSearchFunction(int[] array, int target){// 创建一个Dictionary用于存储数…

this是什么?为什么要改变this?怎么改变 this 指向?

目录 this 是什么&#xff1f; 箭头函数中的 this 为什么要改变 this 指向&#xff1f; 改变 this 指向的三种方法 call(无数个参数) apply(两个参数) bind(无数个参数) this 是什么&#xff1f; 在对象方法中&#xff0c;this 指的是所有者对象&#xff08;方法的拥有者…

程序人生——Java数组和集合使用建议(1)

目录 引出数组和集合建议60&#xff1a;性能考虑&#xff0c;数组是首选建议61&#xff1a;若有必要&#xff0c;使用变长数组建议62&#xff1a;警惕数组的浅拷贝 建议63&#xff1a;在明确的场景下&#xff0c;为集合指定初始容量建议64&#xff1a;多种最值算法&#xff0c;…