這篇文章主要講解了“Java ReentrantLock的反例和正例用法介紹”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Java ReentrantLock的反例和正例用法介紹”吧!
創(chuàng)新新互聯(lián),憑借十載的成都做網(wǎng)站、成都網(wǎng)站制作經(jīng)驗(yàn),本著真心·誠(chéng)心服務(wù)的企業(yè)理念服務(wù)于成都中小企業(yè)設(shè)計(jì)網(wǎng)站有上千案例。做網(wǎng)站建設(shè),選成都創(chuàng)新互聯(lián)。
在finally中釋放鎖
使用 ReentrantLock 時(shí)一定要記得釋放鎖,否則就會(huì)導(dǎo)致該鎖一直被占用,其他使用該鎖的線程則會(huì)永久的等待下去,所以我們?cè)谑褂?ReentrantLock 時(shí),一定要在finally中釋放鎖,這樣就可以保證鎖一定會(huì)被釋放。
反例
import java.util.concurrent.locks.ReentrantLock; publicclass LockExample { // 創(chuàng)建鎖對(duì)象 privatestaticfinal ReentrantLock lock = new ReentrantLock(); public static void main(String[] args) { // 加鎖操作 lock.lock(); System.out.println("Hello,ReentrantLock."); // 此處會(huì)報(bào)異常,導(dǎo)致鎖不能正常釋放 int number = 1 / 0; // 釋放鎖 lock.unlock(); System.out.println("鎖釋放成功!"); } }
當(dāng)出現(xiàn)異常時(shí)鎖未被正常釋放,這樣就會(huì)導(dǎo)致其他使用該鎖的線程永久的處于等待狀態(tài)。
正例
import java.util.concurrent.locks.ReentrantLock; publicclass LockExample { // 創(chuàng)建鎖對(duì)象 privatestaticfinal ReentrantLock lock = new ReentrantLock(); public static void main(String[] args) { // 加鎖操作 lock.lock(); try { System.out.println("Hello,ReentrantLock."); // 此處會(huì)報(bào)異常 int number = 1 / 0; } finally { // 釋放鎖 lock.unlock(); System.out.println("鎖釋放成功!"); } } }
雖然方法中出現(xiàn)了異常情況,但并不影響 ReentrantLock 鎖的釋放操作,這樣其他使用此鎖的線程就可以正常獲取并運(yùn)行了。
感謝各位的閱讀,以上就是“Java ReentrantLock的反例和正例用法介紹”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Java ReentrantLock的反例和正例用法介紹這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!