成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

獨家報道 lock.lock() 寫在 try 外面?

開發(fā) 前端
ReentrantLock 是 JDK 提供的可重入的鎖。提供對 共享資源的獨占訪問,一次只能有一個線程可以獲取該鎖。

[[378852]]

本文轉(zhuǎn)載自微信公眾號「源碼興趣圈」,作者龍臺。轉(zhuǎn)載本文請聯(lián)系源碼興趣圈公眾號。

前言

面試官:小伙子,JUC 并發(fā)包下的可重入鎖 ReentrantLock 在代碼里實際使用過么

混子:用過,ReentrantLock 是 JDK 提供的可重入的鎖。提供對 共享資源的獨占訪問,一次只能有一個線程可以獲取該鎖

面試官:你覺得,ReentrantLock#lock 方法寫到 try 語句外面還是里面

混子:我......

面試官:我們不合適,你走吧

先給出結(jié)論,lock.lock() 最規(guī)范的寫法是寫到 try 語句的外面

lock.lock()

Oracle 文檔中在介紹鎖的使用時有一段代碼,我們以 ReentrantLock 舉例,代碼如下所示:

  1. ReentrantLock lock = new ReentrantLock(); 
  2. lock.lock(); 
  3. try { 
  4.     // access the resource protected by this lock 
  5. } finally { 
  6.     lock.unlock(); 

Q:為什么要把 lock.unlock() 放到 finally 語句塊?

A:為了保證當前線程執(zhí)行過程中出現(xiàn)異常時,鎖依然能被釋放掉,避免死鎖的產(chǎn)生

我們來改動一下上面的代碼,看看會產(chǎn)生什么樣的影響

  1. ReentrantLock lock = new ReentrantLock(); 
  2. try { 
  3.     lock.lock(); 
  4.     // access the resource protected by this lock 
  5. } finally { 
  6.     lock.unlock(); 

看著沒問題呀,為啥文章開始不建議這么用?先說下可能會存在的問題

異常堆棧丟失

假設(shè)在 lock.lock 方法中加鎖異常(千萬不要杠),那么會進入 finally 語句塊中進行解鎖

繼續(xù)跟進,看一下 lock.unlock() 源碼中是如何處理的

lock.lock() 拋出異常有可能還沒獲取到鎖,那么 解鎖源碼中將當前線程比較擁有鎖線程肯定是不相等的,所以會拋出 IMSE (IllegalMonitorStateException)異常

我重寫了 ReentrantLock 加鎖代碼的邏輯,在里面拋出了異常,一起看下會出現(xiàn)什么情況

  1. final void lock() { 
  2.     // 模擬加鎖未成功就拋出異常 
  3.     if (true) { 
  4.         throw new RuntimeException("報錯啦!!!"); 
  5.     } 
  6.     if (compareAndSetState(0, 1)) 
  7.         setExclusiveOwnerThread(Thread.currentThread()); 
  8.     else 
  9.         acquire(1); 

根據(jù)下圖可以看出 加鎖時異常堆棧被 "吞掉了",悄無聲息的就沒了。當然這只是舉例,但是誰能保證加鎖未成功時不會拋出異常呢

真實存在的 BUG

上面代碼示例中都是在 try 的第一行寫 lock,出現(xiàn)問題的可能性極低。這里給大家提供一個反面教材,千萬千萬不要有這種類似行為

示例代碼中把 lock 放到了 try 語句塊里,然后 lock 加鎖前面還有可能會產(chǎn)生異常的代碼,這種就涼了,誰用誰涼的那種

結(jié)尾

所以關(guān)于要不要把 lock.lock() 寫到 try 語句塊里,文章的結(jié)論是:

最好是把 lock.lock() 加鎖方法寫到 try 外面,這是一種規(guī)范,而不是強制

如果你非要寫到 try 里面,那么 請寫到 try 語句塊的第一行,或者 lock 加鎖方法前面不會存在可能出現(xiàn)異常的代碼

最后,如果你代碼中加鎖放到了 try 語句里,麻煩參考第 1 點

 

責(zé)任編輯:武曉燕 來源: 源碼興趣圈
相關(guān)推薦

2013-04-19 10:43:47

ChinaHadoop

2011-11-01 12:48:51

2011-10-27 15:28:09

Citrix思杰Synergy

2009-10-16 14:27:16

甲骨文虛擬化linux

2025-01-16 12:00:00

try-catchfor循環(huán)

2025-04-24 10:56:01

MySQLInnoDB數(shù)據(jù)庫鎖

2024-06-12 14:03:31

MySQLInnoDB

2011-08-24 16:41:38

LOCK中文man

2023-07-06 08:06:47

LockCondition公平鎖

2011-12-12 19:45:19

IBM

2009-08-06 10:35:27

C# lock thi

2010-10-14 17:17:07

軟考2010年下半年軟考試題

2017-02-14 10:00:19

Java開發(fā)Lock

2021-01-28 23:26:55

MySQL

2024-01-02 14:17:31

MySQLMDL LOCK語句

2009-08-26 15:16:29

C# lock關(guān)鍵字

2010-05-24 10:45:52

子命令Svn lock

2011-11-28 12:55:37

JavaJVM

2024-05-06 07:10:00

李飛飛智能空間

2009-11-16 19:11:29

HPCxeon高性能計算
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 久久一区二区av | 午夜影院污 | av在线一区二区三区 | www.久久| 亚洲国产精品一区二区三区 | 亚洲福利片 | 97人人爱 | 91精品国产综合久久久久久丝袜 | 久久国产婷婷国产香蕉 | 亚洲一页| 精品国产一级片 | h在线免费观看 | 日韩久草| 成人三级视频 | 天天草天天射 | 91看片在线| 成年网站在线观看 | 一本岛道一二三不卡区 | 久久精品亚洲精品国产欧美 | 日韩一二区在线 | 国产清纯白嫩初高生视频在线观看 | 亚洲一区二区在线电影 | 国产精品国产a级 | 免费成人高清在线视频 | 99热首页| 国产精品视频一二三区 | 男女视频在线观看免费 | 亚洲国产精品99久久久久久久久 | 成人免费精品视频 | 欧美日韩久久久 | 亚洲男人的天堂网站 | 伊人春色在线 | 欧美一级在线观看 | 欧美视频二区 | 韩国理论电影在线 | 欧美成人一级 | 日韩成人免费视频 | 麻豆成人在线视频 | 久久精品久久久久久 | 久久精品亚洲一区 | 中文字幕国产第一页 |