并发编程要点
Java并发编程中的三大特性分别是原子性、可见性和有序性,它们分别靠以下机制实现:
-
原子性:原子性指的是对于一个操作,要么全部执行,要么全部不执行。Java提供了一些原子性操作,例如AtomicInteger等,它们使用了底层的CAS(Compare and Swap)操作来保证操作的原子性。CAS操作是一种乐观锁技术,当期望值和实际值相同时,才会进行更新操作,否则会进行重试。
-
可见性:可见性指的是当一个线程对共享变量进行修改后,其他线程能够立即看到这个值的改变。Java中,可以使用volatile关键字来保证变量的可见性。volatile关键字可以保证该变量对于所有线程的可见性,即当一个线程修改了该变量的值后,其他线程能够立即看到这个值的改变。同时,在JMM规范中,对于volatile变量的读取操作和写入操作会在读操作之前插入Load with Barrier屏障,保证该操作之前的所有写操作都已经完成,同时在写操作之后插入Store with Barrier屏障,保证该操作之后的所有读操作都能看到修改后的值。这样可以保证对于volatile变量的访问操作具有原子性、有序性和可见性。
-
有序性:有序性指的是对于一个线程内的操作,它们的执行顺序是按照代码顺序执行的。在Java中,可以使用synchronized关键字和Lock对象等同步机制来保证线程内的有序性。这些同步机制会保证同步代码块内的代码按照代码顺序执行,从而保证了有序性。
总的来说,Java并发编程中的三大特性分别是原子性、可见性和有序性。原子性可以通过原子性操作和CAS操作来保证;可见性可以通过volatile关键字来保证;有序性可以通过同步机制(synchronized关键字和Lock对象)来保证。
Volitile关键字
在Java中,使用volatile关键字声明的变量具有特殊的属性。volatile关键字可以保证该变量对于所有线程的可见性,即当一个线程修改了该变量的值后,其他线程能够立即看到这个值的改变。volatile关键字可以解决多线程访问共享变量时出现的线程安全问题。
在JMM规范中,对于volatile变量的读取操作和写入操作,会在读操作之前插入Load with Barrier屏障,保证该操作之前的所有写操作都已经完成,同时在写操作之后插入Store with Barrier屏障,保证该操作之后的所有读操作都能看到修改后的值。这样可以保证对于volatile变量的访问操作具有原子性、有序性和可见性。
使用volatile关键字修饰的变量在修改值时不会被本地线程缓存,而是直接操作主内存中的变量,因此能够保证变量的可见性。同时,由于volatile关键字可以保证变量的可见性,因此也可以保证使用该变量的操作是原子性的。
需要注意的是,volatile关键字只能保证对单个变量操作的原子性和可见性,并不能保证一系列操作的原子性,例如i++操作。如果需要保证多个操作的原子性,可以使用synchronized关键字或者Lock对象等同步机制。
总之,volatile关键字是Java中用于解决多线程访问共享变量时出现的线程安全问题的一种手段,可以保证变量的可见性和操作的原子性。
volatile关键字可以保证变量对于所有线程的可见性,并且禁止指令重排序。为了实现这些特性,JMM在编译器和处理器的操作之间插入了特定类型的内存屏障,分别是:
-
Load with Barrier屏障(LoadLoad屏障):这个屏障用于保证volatile读操作之前的所有读操作和写操作都已经完成。
-
Store with Barrier屏障(StoreStore屏障):这个屏障用于保证volatile写操作之后的所有写操作都已经完成。
-
Store with Load屏障(StoreLoad屏障):这个屏障用于保证volatile写操作之后,对于volatile变量的读操作能够读取到修改后的最新值。
这些内存屏障都是通过编译器和处理器来实现的,编译器会在生成字节码时插入相关的指令,处理器在执行指令时会根据相关的屏障来保证指令的执行顺序和可见性。通过这些屏障,JMM保证了volatile变量的可见性、有序性和原子性。
Synchronize关键字
synchronized是Java中一种用于实现线程同步的关键字,其底层实现主要涉及到对象头、Monitor(监视器)和锁升级三个方面。
-
对象头:在Java对象头中,有一块用于存储锁信息的部分,包括锁标记、偏向线程ID、偏向时间戳等信息。synchronized关键字就是利用了Java对象头中的锁标记来实现线程同步的。
-
Monitor:Monitor是一种同步机制,用于实现线程的互斥和协作。在Java虚拟机中,每个对象都会与一个Monitor相关联。当一个线程进入synchronized代码块时,会尝试获取该对象的Monitor,如果该Monitor已经被其他线程占用,那么该线程就会被阻塞。
-
锁升级:Java中的锁有多种状态,包括无锁状态、偏向锁状态、轻量级锁状态和重量级锁状态。synchronized关键字使用的是重量级锁,但是在竞争不激烈的情况下,可以使用偏向锁或轻量级锁来优化性能。偏向锁是指在没有竞争的情况下,将锁标记设置为偏向线程的ID,使得该线程可以不需要每次都去竞争锁,提高了程序的运行效率。轻量级锁是指在竞争不激烈的情况下,使用CAS操作来实现锁的获取和释放,避免了线程的上下文切换,也提高了程序的运行效率。但是如果竞争激烈,轻量级锁就会升级为重量级锁,这样就会带来较大的性能损失。
总的来说,synchronized关键字的底层实现主要涉及到对象头、Monitor和锁升级三个方面。在Java虚拟机中,每个对象都会与一个Monitor相关联,当一个线程进入synchronized代码块时,会尝试获取该对象的Monitor。synchronized关键字使用的是重量级锁,但是在竞争不激烈的情况下,可以使用偏向锁或轻量级锁来优化性能。
相关文章:
并发编程要点
Java并发编程中的三大特性分别是原子性、可见性和有序性,它们分别靠以下机制实现: 原子性:原子性指的是对于一个操作,要么全部执行,要么全部不执行。Java提供了一些原子性操作,例如AtomicInteger等…...

HDFS黑名单退役服务器
黑名单:表示在黑名单的主机IP地址不可以,用来存储数据。 企业中:配置黑名单,用来退役服务器。 黑名单配置步骤如下: 1)编辑/opt/module/hadoop-3.1.3/etc/hadoop目录下的blacklist文件 添加如下主机名称&…...

基于stm32智能语音电梯消毒系统
这次来分享个最近做的项目,stm32智能语音电梯消毒系统功能说明:在电梯,房间,客道区域内,检测到人,则执行相关动作!例如继电器开关灯,喷洒酒精等行为。手机app/微信小程序可以控制需要…...

FreeRTOS系列第1篇---为什么选择FreeRTOS?
1.为什么学习RTOS? 作为基于ARM7、Cortex-M3硬件开发的嵌入式工程师,我一直反对使用RTOS。不仅因为不恰当的使用RTOS会给项目带来额外的稳定性风险,更重要的是我认为绝大多数基于ARM7、Cortex-M3硬件的项目,还没复杂到使用RTOS的地…...

基于.NET Core内置浏览器窗体应用程序界面框架
更多开源项目请查看:一个专注推荐.Net开源项目的榜单 平常我们在做项目过程中,桌面软件具备操作高效、利用本地计算机做一些复杂运算、或者设定快捷操作等优势,但是桌面软件也有很多缺点,比如升级问题、系统兼容问题、系统bug排查…...

【数据结构初阶】一文带你学会归并排序(递归非递归)
目录 前言 递归实现 代码实现 非递归实现 代码实现 总结 前言 归并排序(Merge sort)是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。 作为一种典型的分而治之思想…...

Simulink壁咚(一)——What and How
目录 一、前言 二、Simulink 知多少 三、滤波算法 四、Model Verification 五、Model Coverage 六、Simulink测试实例 七、Simulink Test 八、Test Manager 九、Test Harness 十、 学习 一、前言 Simulink从2017b以后更加工程化和实用化,基于MBD的功能日趋…...

【PyTorch】Pytorch基础第0章
本文参加新星计划人工智能(Pytorch)赛道:https://bbs.csdn.net/topics/613989052 这是目录PyTorch的简介PyTorch 构建深度学习模型的步骤搭建pytorch使用环境PyTorch的简介 PyTorch 是一个开源的机器学习框架,由 Facebook 的人工智能研究院(…...
Android学习总结
积累熟练掌握 Java 语言,面向对象分析设计能力,反射原理,自定义注解及泛型,多次采用设计模式重构公司项目;熟练掌握 IVM 原理,反射,动态代理以及对 ClassLoader 热修复有比较深的理解࿱…...

虚拟机ubuntu安装samba服务
安装samba apt-get install samba 新建一个共享目录 mkdir /home/l/work chmod 777 /home/l/work 配置服务 配置 /etc/samba/smb.confsudo smbpasswd -a l(添加用户名名称) 防火墙关闭 Ubuntu中 我们使用命令查看当前防火墙状态; sudo ufw status inactive状态是防火墙关闭…...

开发板中的内存压力测试,你了解多少?
1. 测试目的内存压力测试的目的是评估开发板中的内存子系统性能和稳定性,以确保它能够满足特定的应用需求。开发板通常用于嵌入式系统、物联网设备、嵌入式智能家居等场景,这些场景对内存的要求通常比较高。其内存压力测试的主要目的有:1.对确…...

MATLAB | 这些花里胡哨的热图怎么画
好早之前写过一个绘制相关系数矩阵的代码,但是会自动求相关系数,而且画出来的热图只能是方形,这里写一款允许nan值出现,任意形状的热图绘制代码,绘制效果如下: 如遇到bug请后台提出,并去gitee下…...
Java开发的一些编码建议
1、无论是类、方法、字段、变量,尽可能的限制他们的作用范围,可以避免出现不必要的错误;同时虚拟机也能有更大的优化空间。 2、错误越早发现越好,编译时发生错误比在运行时发生错误好。而且编译时错误能更好的定位问题所在。 这…...

【YOLOv8/YOLOv7/YOLOv5/YOLOv4/Faster-rcnn系列算法改进NO.59】引入ASPP模块
前言作为当前先进的深度学习目标检测算法YOLOv8,已经集合了大量的trick,但是还是有提高和改进的空间,针对具体应用场景下的检测难点,可以不同的改进方法。此后的系列文章,将重点对YOLOv8的如何改进进行详细的介绍&…...

C++STL set/multiset容器 构造和赋值 大小和交换 插入和删除 查找和统计
文章目录set/multiset容器1 set容器 基本概念2 set容器 构造和赋值3 set容器 大小和交换4 set容器 插入和删除5 set容器 查找和统计set/multiset容器 1 set容器 基本概念 简介: 所有元素都会在插入时会被自动排序,例如,在set容器放入元素1、…...

产品研发项目进度管理软件工具有哪些推荐?整理10款最佳进度管理软件
项目进度管理是确保项目按时完成的关键过程,使用合适的项目进度管理工具能确保帮助项目管理者实时了解和控制项目的进展情况,及时发现和解决问题,减少项目风险,提高项目效率和管理水平。这里将整理出国内外最受欢迎的10款项目进度…...

「ML 实践篇」分类系统:图片数字识别
目的:使用 MNIST 数据集,建立数字图像识别模型,识别任意图像中的数字; 文章目录1. 数据准备(MNIST)2. 二元分类器(SGD)3. 性能测试1. 交叉验证2. 混淆矩阵3. 查准率与查全率4. P-R 曲…...

从大专到测开,上海某字母站大厂的面试题,岗位是测开(25K*16)
简单介绍一句,大专出身,三年经验。跳了四次槽,面试了无数次,现在把自己的面试经验整理出来分享给大家,堪称必杀技! 1,一切从实际出发,对实际工作进行适当修饰 2,不会的简…...

【面试题】Python软件工程师能力评估试题(一)
文章目录前言应试者需知(一)Python 语言基础能力评估1、理解问题并完成代码:2、阅读理解代码,并在空白处补充完整代码:3、编写一个装饰器:exposer4、阅读代码并在空白处补充完整代码:5、自行用P…...
Java八股文(Java多线程面试题)
并行和并发的区别?(1)并行是指两个或者多个事件在同一时刻发生;而并发是指两个或多个事件在同一时间间隔发生;(2)并行是在不同实体上的多个事件,并发是在同一实体上的多个事件&#…...
【Linux】shell脚本忽略错误继续执行
在 shell 脚本中,可以使用 set -e 命令来设置脚本在遇到错误时退出执行。如果你希望脚本忽略错误并继续执行,可以在脚本开头添加 set e 命令来取消该设置。 举例1 #!/bin/bash# 取消 set -e 的设置 set e# 执行命令,并忽略错误 rm somefile…...

2021-03-15 iview一些问题
1.iview 在使用tree组件时,发现没有set类的方法,只有get,那么要改变tree值,只能遍历treeData,递归修改treeData的checked,发现无法更改,原因在于check模式下,子元素的勾选状态跟父节…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...

安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)
船舶制造装配管理现状:装配工作依赖人工经验,装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书,但在实际执行中,工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...

三分算法与DeepSeek辅助证明是单峰函数
前置 单峰函数有唯一的最大值,最大值左侧的数值严格单调递增,最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值,最小值左侧的数值严格单调递减,最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...

Web后端基础(基础知识)
BS架构:Browser/Server,浏览器/服务器架构模式。客户端只需要浏览器,应用程序的逻辑和数据都存储在服务端。 优点:维护方便缺点:体验一般 CS架构:Client/Server,客户端/服务器架构模式。需要单独…...

手机平板能效生态设计指令EU 2023/1670标准解读
手机平板能效生态设计指令EU 2023/1670标准解读 以下是针对欧盟《手机和平板电脑生态设计法规》(EU) 2023/1670 的核心解读,综合法规核心要求、最新修正及企业合规要点: 一、法规背景与目标 生效与强制时间 发布于2023年8月31日(OJ公报&…...
Java求职者面试指南:Spring、Spring Boot、Spring MVC与MyBatis技术解析
Java求职者面试指南:Spring、Spring Boot、Spring MVC与MyBatis技术解析 一、第一轮基础概念问题 1. Spring框架的核心容器是什么?它的作用是什么? Spring框架的核心容器是IoC(控制反转)容器。它的主要作用是管理对…...