《Java并发编程的艺术》读后笔记-part2

news/2024/12/21 21:18:39/

在这里插入图片描述

1.volatile的应用

在多线程并发编程中synchronizedvolatile都扮演着重要角色。与synchronized不同的是,volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的“可见性”

可见性:当一个线程修改一个共享变量时,另外一个线程能读到这个修改的值。如果volatile变量修饰符使用恰当的话,它比synchronized的使用和执行成本更低,因为它不会引起线程上下文的切换和调度

1.1volatile的定义与实现原理

在我们了解实现原理之前先了解一下CPU的术语,便于后续理解。话不多说,直接上图:

在这里插入图片描述

volatile是如何来保证可见性的呢?

我们这里用汇编指令来具体解析有volatile和无volatile的区别。

Java代码:

instance = new Singleton(); // instance是volatile变量

转变成的汇编代码,如下:

0x01a3de1d: movb $0×0,0×1104800(%esi);

0x01a3de24: lock addl $0×0,(%esp);

volatile变量修饰的共享变量进行写操作的时候会多出第二行汇编代码,通过查IA-32架构软件开发者手册可知,Lock前缀的指令在多核处理器下会引发了两件事情:

  1. 将当前处理器缓存行的数据写回到系统内存。

  2. 这个写回内存的操作会使在其他CPU里缓存了该内存地址的数据无效。

  • MESI(缓存⼀致性协议):当CPU写数据时,如果发现操作的变量是共享变量,即在其他CPU中也存在该变量的副本,会发出信号通知其他CPU将该变量的缓存行置为无效状态,因此当其他CPU需要读取这个变量时,发现自己缓存中缓存该变量的缓存行是无效的,那么它就会从内存重新读取

  • 嗅探:每个处理器通过嗅探在总线上传播的数据来检查自己缓存的值是不是过期了,当处理器发现自己缓存行对应的内存地址被修改,就会将当前处理器的缓存行设置成无效状态,当处理器对这个数据进行修改操作的时候,会重新从系统内存中把数据读到处理器缓存里。

2.synchronized的实现原理和应用

我们先来看看synchronized的三种表现形式:

  1. 对于普通同步方法,锁是当前实例对象。

public synchronized void xpp() {

}

  1. 对于静态同步方法,锁是当期类的Class对象。

public void xpp() {

synchronized (demo1Main1.class) ;

}

  1. 对于同步方法块,锁是synchronized括号里配置的对象。

public void xpp3() {

synchronized (new test()) {

}

}

2.1Java对象头

synchronized用的锁是存在Java对象头里的。

Java对象头里的Mark Word里默认存储对象的HashCode、分代年龄和锁标记位。如图(这里是32位的虚拟机):

在这里插入图片描述

在运行期间,Mark Word里存储的数据会随着锁标志位的变化而变化。Mark Word可能变化为存储以下4种数据:

在这里插入图片描述

2.2锁的升级与对比

锁一共有四种状态,级别从低到高为:无锁状态偏向锁状态轻量级锁状态重量级锁状态

需要注意的是,这几个状态会随着竞争情况逐渐升级。锁可以升级但不能降级。这种锁升级却不能降级的策略,目的是为了提高获得锁和释放锁的效率

  1. 偏向锁

大多数情况下,锁不仅不存在多线程竞争,而且总是由同一线程多次获得,为了让线程获得锁的代价更低而引入了偏向锁。

偏向锁使用了一种等到竞争出现才释放锁的机制,所以当其他线程尝试竞争偏向锁时,持有偏向锁的线程才会释放锁。

  1. 轻量级锁

当锁是偏向锁的时候,被其他线程访问,偏向锁就会升级为轻量级锁,其他线程会通过自旋的形式尝试获取锁,但不会阻塞,且性能会高点!

  1. 重量级锁

当锁为轻量级锁的时候,其他线程虽然是自旋,但自旋不会一直循环下去,当自旋一定次数的时候且还没有获取到锁,就会进入阻塞,该锁升级为重量级锁,重量级锁会让其他申请的线程进入阻塞,性能也会降低!

三种锁的优缺点对比:

在这里插入图片描述

3.原子操作的实现原理

原子操作:不可被中断的一个或一系列操作。

最后

最后,强调几点:

  • 1. 一定要谨慎对待写在简历上的东西,一定要对简历上的东西非常熟悉。因为一般情况下,面试官都是会根据你的简历来问的; 能有一个上得了台面的项目也非常重要,这很可能是面试官会大量发问的地方,所以在面试之前好好回顾一下自己所做的项目;
  • 2. 和面试官聊基础知识比如设计模式的使用、多线程的使用等等,可以结合具体的项目场景或者是自己在平时是如何使用的;
  • 3. 注意自己开源的Github项目,面试官可能会挖你的Github项目提问;

我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!

以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目。

面试答案

三面头条+四面阿里+五面腾讯拿offer分享面经总结,最终入职阿里

三面头条+四面阿里+五面腾讯拿offer分享面经总结,最终入职阿里

三面头条+四面阿里+五面腾讯拿offer分享面经总结,最终入职阿里

,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!

以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目。

面试答案

[外链图片转存中…(img-6vZeNRQg-1726121342987)]

[外链图片转存中…(img-xkwau29P-1726121342988)]

[外链图片转存中…(img-kG95002i-1726121342988)]


http://www.ppmy.cn/news/1524463.html

相关文章

如何根据企业的实际需求设计 cmdb系统

以下是根据企业实际需求设计配置管理数据库(CMDB)系统的步骤: 一、明确需求和目标 业务需求分析 与企业各部门沟通,了解他们对 IT 资源信息的需求。例如,运维团队可能需要准确的服务器配置信息以快速解决故障&#xff…

[数据集][目标检测]电动车入梯进电梯电单车入梯检测数据集VOC+YOLO格式7106张3类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):7106 标注数量(xml文件个数):7106 标注数量(txt文件个数):7106 标注…

ArcGIS Pro SDK (十三)地图创作 5 图层样式

ArcGIS Pro SDK (十三)地图创作 5 图层样式 文章目录 ArcGIS Pro SDK (十三)地图创作 5 图层样式1 风格管理1.1 如何按名称获取项目中的样式1.2 如何创建新样式1.3 如何向项目添加样式1.4 如何从项目中删除样式1.5 如何将样式项添加到样式1.6 如何从样式中删除样式项1.7 如…

【软件合集】电脑桌面整理工具、DLL修复工具、文件加密等11款电脑必备软件,高效办公!

经常使用电脑办公的用户一定知道,第三方软件对于提高办公效率的影响力有多高! 除了电脑自带的功能之外,市面上还有很多好用的电脑软件,一款好用的电脑软件可以提高我们的办公效率,节省时间。 本期内容,小编…

博物馆如何实现3D交互控制展示?

如果是想实现可交互控制的3D展示,推荐一下博维数孪(Bowell),他家实现这样的需求非常非常简单,对3D美术人员来说完全没有任何门槛和难度,具体方式可以通过以下步骤进行: 1、准备3D模型&#xff…

漫谈设计模式 [19]:责任链模式

引导性开场 菜鸟:老鸟,我最近在项目中遇到了一些问题。我们有很多业务逻辑需要处理,但代码变得越来越难以维护。每当有新需求时,修改代码都让我头疼。 老鸟:听起来你遇到了典型的代码复杂性问题。你是否听说过设计模…

Unity3D帧同步模式的网络游戏详解

帧同步概述 帧同步(Frame Synchronization)是指在网络游戏中,多个客户端在同一时刻执行相同的游戏逻辑,确保各个客户端的游戏状态保持一致。这种同步方式对于实现公平的多人游戏和减少网络延迟对游戏体验的影响至关重要。Unity3D…

28BYJ-48步进电机详解(五线四相 STM32)

目录 一、介绍 二、模块原理 1.工作原理介绍 2.ULN2003驱动模块原理图 3.引脚描述 三、程序设计 main.c文件 stepmotor.h文件 stepmotor.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 步进电机(STEP MOTOR)把电脉冲信号变换成角位移…