电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java synchronize底層實現原理及優化

瀏覽:99日期:2022-09-04 11:04:31

首先來說下synchronize和Lock的區別:

兩者都是鎖,用來控制并發沖突,區別在于Lock是個接口,提供的功能更加豐富,除了這個外,他們還有如下區別:

synchronize自動釋放鎖,而Lock必須手動釋放,并且代碼中出現異常會導致unlock代碼不執行,所以Lock一般在Finally中釋放,而synchronize釋放鎖是由JVM自動執行的。 Lock有共享鎖的概念,所以可以設置讀寫鎖提高效率,synchronize不能。(兩者都可重入) Lock可以讓線程在獲取鎖的過程中響應中斷,而synchronize不會,線程會一直等待下去。lock.lockInterruptibly()方法會優先響應中斷,而不是像lock一樣優先去獲取鎖。 Lock鎖的是代碼塊,synchronize還能鎖方法和類。 Lock可以知道線程有沒有拿到鎖,而synchronize不能

Lock鎖對應有源碼的,可以查看下代碼,那么synchronize在JVM層面是怎么實現的呢,我們看下字節碼文件:

先用javac Test.class 編譯出class文件再用javap ?c Test.class查看字節碼文件

我們寫個DEMO看下,JVM底層是怎么實現synchronized的:、

public class Test4 { private static Object LOCK = new Object(); public static int main(String[] args) { synchronized (LOCK){ System.out.println('Hello World'); } return 1; }}

在看下上面代碼對應的字節碼

Java synchronize底層實現原理及優化

也就是說,鎖是通過monitorenter和monitorexit來實現的,這兩個字節碼代表的是啥意思:

可以在下面參考的網頁中了解monitorenter和monitorexit的作用,我就不盜用他們的話了,大致意思是,每個對象都有一個monitor監視器,調用monitorenter就是嘗試獲取這個對象,成功獲取到了就將值+1,離開就將值減1。如果是線程重入,在將值+1,說明monitor對象是支持可重入的。

我之前分析過一篇ReenternLock,概念都是類似的,只是鎖是自身維護了一個volatile int類型的變量,通過對它加一減一表示占有鎖啊重入之類的概念。

注意,如果synchronize在方法上,那就沒有上面兩個指令,取而代之的是有一個ACC_SYNCHRONIZED修飾,表示方法加鎖了。它會在常量池中增加這個一個標識符,獲取它的monitor,所以本質上是一樣的。

HotSpot中鎖的具體實現以及對它的優化:

重量級鎖:

最基礎的實現方式,JVM會阻塞未獲取到鎖的線程,在鎖被釋放的時候喚醒這些線程。阻塞和喚醒操作是依賴操作系統來完成的,所以需要從用戶態切換到內核態,開銷很大。并且monitor調用的是操作系統底層的互斥量(mutex),本身也有用戶態和內核態的切換,所以JVM引入了自旋的概念,減少上面說的線程切換的成本。

自旋鎖:

如果鎖被其他線程占用的時間很短,那么其他獲取鎖的線程只要稍微等一下就好了,沒必要進行用戶態和內核態之間的切換,等的狀態就叫自旋。例如如下代碼:

public class SpinLock { private AtomicReference<Thread> cas = new AtomicReference<Thread>(); public void lock() { Thread current = Thread.currentThread(); // 利用CAS,獲取值不對則無限循環 while (!cas.compareAndSet(null, current)) { // DO nothing } } public void unlock() { Thread current = Thread.currentThread(); cas.compareAndSet(current, null); }}

自旋會跑一些無用的CPU指令,所以會浪費處理器時間,如果鎖被其他線程占用的時間段的話確實是合適的…如果長的話就不如使用直接阻塞了,那么JVM怎么知道鎖被占用的時間到底是長還是短呢?

因為JVM不知道鎖被占用的時間長短,所以使用的是自適應自旋。就是線程空循環的次數時會動態調整的。

可以看出,自旋會導致不公平鎖,不一定等待時間最長的線程會最先獲取鎖。

輕量級鎖:

JDK1.6之后加入,它的目的并不是為了替換前面的重量級鎖,而是在實際沒有鎖競爭的情況下,將申請互斥量這步也省掉。鎖實現的核心在與對象頭(MarkWord)的結構,對象自身會有信息表示所有被鎖住并且鎖是什么類型,如下所示:

Java synchronize底層實現原理及優化

如果代碼進入同步塊時,檢測到對象未鎖定,即標志位為01。那么當前線程就會在自身棧幀中建議一個區域保存對象的MarkWord信息,再使用CAS的方式讓這個區域指向對象的MarkWork區域,這樣就算加上鎖了。(這樣就沒有獲取系統mutex變量,只是改了個值,但是如果有競爭的話,就要升級成重量級鎖,這樣反倒變慢了)

加鎖前VS 加鎖后:

Java synchronize底層實現原理及優化

偏向鎖:

比輕量級鎖更絕,將同步操作全部省略…設置步驟是和前面的輕量級鎖一樣的,不同的是標志位設置的是01,即偏向模式。

不同的是同一個線程第二次進來之后,虛擬機不會再進行任何的同步操作,比如Mark Word的update。

如果有其他線程來,偏向模式就結束了,標志位會恢復到未鎖定或者偏向鎖。所以如果鎖總是會被多個線程訪問的話,還是禁止掉偏向鎖優化比較好。

鎖優化流程如下:(出自周志明老師的那本講解JVM的書)

Java synchronize底層實現原理及優化

可以看出,鎖是一個逐步升級的過程,不會一開始上來就重量級鎖。鎖一般只會升級不會降級,避免降級之后沖突導致效率不行并且又得升級。但是降級其實是允許的(STW的時候),可以看下參考中文章里面提到的英文網站。

其他的優化還有鎖消除以及鎖粗化:

如果一段代碼其實在作用域可以不加鎖的,Javac編譯器會自動優化。

鎖粗化是指代碼在一段代碼中多次加鎖,會被JVM優化成對整個代碼段加鎖。

(但是這兩點是JVM對代碼的優化,而不是對synchronized優化了,這里只是順帶提一下)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 安规_综合测试仪,电器安全性能综合测试仪,低压母线槽安规综合测试仪-青岛合众电子有限公司 | 智能垃圾箱|垃圾房|垃圾分类亭|垃圾分类箱专业生产厂家定做-宿迁市传宇环保设备有限公司 | 四探针电阻率测试仪-振实密度仪-粉末流动性测定仪-宁波瑞柯微智能 | 食品无尘净化车间,食品罐装净化车间,净化车间配套风淋室-青岛旭恒洁净技术有限公司 | 成都亚克力制品,PVC板,双色板雕刻加工,亚克力门牌,亚克力标牌,水晶字雕刻制作-零贰捌广告 | 脉冲除尘器,除尘器厂家-淄博机械 | 数字展示在线_数字展示行业门户网站 | 【化妆品备案】进口化妆品备案流程-深圳美尚美化妆品有限公司 | 常州律师事务所_常州律所_常州律师-江苏乐天律师事务所 | 全自动包衣机-无菌分装隔离器-浙江迦南科技股份有限公司 | MTK核心板|MTK开发板|MTK模块|4G核心板|4G模块|5G核心板|5G模块|安卓核心板|安卓模块|高通核心板-深圳市新移科技有限公司 | 直齿驱动-新型回转驱动和回转支承解决方案提供商-不二传动 | 模具钢_高速钢_不锈钢-万利钢金属材料 | 掺铥光纤放大器-C/L波段光纤放大器-小信号光纤放大器-合肥脉锐光电技术有限公司 | 【ph计】|在线ph计|工业ph计|ph计厂家|ph计价格|酸度计生产厂家_武汉吉尔德科技有限公司 | 回转支承-转盘轴承-回转驱动生产厂家-洛阳隆达轴承有限公司 | 无压烧结银_有压烧结银_导电银胶_导电油墨_导电胶-善仁(浙江)新材料 | 校园文化空间设计-数字化|中医文化空间设计-党建|法治廉政主题文化空间施工-山东锐尚文化传播公司 | 【法利莱住人集装箱厂家】—活动集装箱房,集装箱租赁_大品牌,更放心 | TPU薄膜_TPU薄膜生产厂家_TPU热熔胶膜厂家定制_鑫亘环保科技(深圳)有限公司 | 重庆轻质隔墙板-重庆安吉升科技有限公司 | LED太阳能中国结|发光红灯笼|灯杆造型灯|节日灯|太阳能灯笼|LED路灯杆装饰造型灯-北京中海轩光电 | 江苏皓越真空设备有限公司 | 广域铭岛Geega(际嘉)工业互联网平台-以数字科技引领行业跃迁 | 家用净水器代理批发加盟_净水机招商代理_全屋净水器定制品牌_【劳伦斯官网】 | 汽车整车综合环境舱_军标砂尘_盐雾试验室试验箱-无锡苏南试验设备有限公司 | 餐饮加盟网_特色餐饮加盟店_餐饮连锁店加盟 | 网带通过式抛丸机,,网带式打砂机,吊钩式,抛丸机,中山抛丸机生产厂家,江门抛丸机,佛山吊钩式,东莞抛丸机,中山市泰达自动化设备有限公司 | 化妆品加工厂-化妆品加工-化妆品代加工-面膜加工-广东欧泉生化科技有限公司 | 一体式钢筋扫描仪-楼板测厚仪-裂缝检测仪-泰仕特(北京) | Maneurop/美优乐压缩机,活塞压缩机,型号规格,技术参数,尺寸图片,价格经销商 | 智能风向风速仪,风速告警仪,数字温湿仪,综合气象仪(气象五要素)-上海风云气象仪器有限公司 | 路斯特伺服驱动器维修,伦茨伺服驱动器维修|万骏自动化百科 | 宽带办理,电信宽带,移动宽带,联通宽带,电信宽带办理,移动宽带办理,联通宽带办理 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | 耐高温风管_耐高温软管_食品级软管_吸尘管_钢丝软管_卫生级软管_塑料波纹管-东莞市鑫翔宇软管有限公司 | 亚克隆,RNAi干扰检测,miRNA定量检测-上海基屹生物科技有限公司 | 风化石头制砂机_方解石制砂机_瓷砖石子制砂机_华盛铭厂家 | 合金ICP光谱仪(磁性材料,工业废水)-百科| 高通量组织研磨仪-多样品组织研磨仪-全自动组织研磨仪-研磨者科技(广州)有限公司 |