并发编程要点
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)并行是在不同实体上的多个事件,并发是在同一实体上的多个事件&#…...
小程序当前页面如何分享别的页面内容呢?
需求分析 因为功能的需要分为两点 他需要调转转发,并且有首页转发点击button按钮进行转发邀请好友帮忙助力,如何做到一个页面多种转发 如何区分,是button转发还剩右上角三个点转发呢? 通过onShareAppMessage()这个函数的事件…...
编写Java哪个编译器好
现在能够编写Java代码的工具简直不要太多,各种各样五花八门,但目前效率最高的还是Intellij Idea。但这个工具对于完全零基础的小白来说,第一次用起来是比较复杂的,因为它的功能太多了。这就好比你要学开车,如果上来就给…...
第十六章 Java为什么使用序列化
为何要指定serialVersionUID的值如果不指定显示serialVersionUID的值,jvm在序列化时会自动生成一个serialVersionUID,跟属性一起序列化,再进行持久化或者网络传输,在反序列化时,jvm会根据属性自动生成一个新版的serial…...
28岁小公司程序员,无车无房不敢结婚,要不要转行?
大家好,这里是程序员晚枫,又来分享程序员的职场故事了~ 今天分享的这位朋友叫小青,我认识他2年多了。以前从事的是土木行业,2年前找我咨询转行程序员的学习路线和职业规划后,通过自学加入了一家创业公司,成…...
出道即封神的ChatGPT,现在怎么样了?
从互联网的普及到智能手机,都让广袤的世界触手而及,如今身在浪潮中的我们,已深知其力。前阵子爆火的ChatGPT,不少人保持观望态度。现如今,国内关于ChatGPT的各大社群讨论,似乎沉寂了不少,现在怎…...
【计算机视觉】CNN 可视化算法
文章目录一、CAM算法1.1 概述1.2 CAM算法介绍二、Grad-CAM算法2.1 概述2.2 Guided Backpropagation2.3 Occlusion Sensitivity2.4 Grad-CAM 整体结构和效果2.5 Grad-CAM 实现细节一、CAM算法 1.1 概述 本文介绍 2016 年提出的 CAM (Class Activation Mapping) 算法࿰…...
自动抓取服务器巡检、登录、执行命令记录+备份脚本
文章目录 引抓取【巡检日志】语言&时区设置语言设置时区巡检脚本执行效果抓取【登录信息】登录脚本登录脚本低版本的last命令执行效果抓取【history记录】说明配置history授权日志文件显示时间戳持久化到日志未配置history的配置过history的执行脚本执行脚本...
如何用Python求解微分方程组
文章目录odeint简介示例odeint简介 scipy文档中将odeint函数和ode, comples_ode这两个类称为旧API,是scipy早期使用的微分方程求解器,但由于是Fortran实现的,尽管使用起来并不方便,但速度没得说,所以有的时候还挺推荐…...
【微信小程序】-- 自定义组件 - behaviors(三十九)
💌 所属专栏:【微信小程序开发教程】 😀 作 者:我是夜阑的狗🐶 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询! &…...
【微信小程序】-- 自定义组件 - 父子组件之间的通信(三十八)
💌 所属专栏:【微信小程序开发教程】 😀 作 者:我是夜阑的狗🐶 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询! &…...
厦门做网站多少/百度官方人工客服电话
一,利用DirectX诊断工具查看硬件配置DirectX诊断工具可以帮助我们对硬件工作情况作出测试、诊断并进行修改,当然我们也可以利用它来查看机器的硬件配置。运行“系统信息”窗口,找到 “工具--DirectX诊断工具”(或者进入安装盘符中Windows目录…...
哪些网站需要备案/怎么在百度发广告
采购单位:天津市房地产经济技术信息中心拟采购的内容:序号 型号 描述 数量 1 Oracle应用服务器套件软件 WebLogic Suite Processor 2cpu 2 Oracle数据同步检测软件 Oracle GoldenGate Veridata Processor 2cpu 3 Oracle数据同步核心软件 O…...
石家庄业之峰装饰公司怎么样/seo推广效果
转自:http://my.eoe.cn/swer03160828/archive/20067.html 1) 如果在win32 下面编写的cocos2dx 的代码其文件 .cpp,.h 的文件,基本上都其他的平台上面可以直接把文件编辑是没有问题的! 2) 大多数的学习游戏开的人,使用的很多都是 w…...
多语言外贸网站建设/开发网站的公司
509.斐波那契数509.斐波那契数题解代码509.斐波那契数 509.斐波那契数 题解 题目是简单,这里用map记忆化,节省时间 代码 package mainvar mp map[int]int make(map[int]int)func fib(n int) int {return dfs(n) } func dfs(n int) int {if n < …...
emlog怎么转wordpress/自动点击器免费下载
称号:仿微型一个源共享 微酷WeiKuCMS管家微信升级2.0版本号(免费)资源主题: 、 资源描叙: 微酷WeiKuCMS。让微信营销如此简单。微酷WeiKuCMS是打造的一个专门针对微信公众账号提供营销推广服务的第三方平台。主要功能是针对微信商家公众号提供与众不同的…...
wordpress EDD Alipay/关键词seo排名公司
在亚马逊云科技,有着这么一群人,他们经常被认为只会写代码,而不善言辞。但这只是大家对他们的误解。他们的工作不仅需要懂开发、善沟通,还需要能够dive deep用户的需求。他们就是亚马逊云科技的 Software Dev Engineer!…...