Lock的lock()方法
ReentrantLock是JDK唯一實(shí)現(xiàn)了Lock接口的類
lock()
是平常使用得最多的一個(gè)方法,就是用來獲取鎖。如果鎖已被其他線程獲取,則進(jìn)行等待。
由于在前面講到如果采用Lock,必須主動(dòng)去釋放鎖,并且在發(fā)生異常時(shí),不會(huì)自動(dòng)釋放鎖。因此一般來說,使用Lock必須在try{}catch{}塊中進(jìn)行,并且將釋放鎖的操作放在finally塊中進(jìn)行,以保證鎖一定被被釋放,防止死鎖的發(fā)生。
實(shí)例
各自獨(dú)立的Lock對象
兩個(gè)線程的lock對象是彼此獨(dú)立,沒有任何關(guān)系,沒有起到鎖的作用@Testpublic void testLock1() {// 兩個(gè)線程的lock對象是彼此獨(dú)立,沒有任何關(guān)系,沒有起到鎖的作用new Thread() {@Overridepublic void run() {Lock lock = new ReentrantLock();String tName=Thread.currentThread().getName();System.out.println(tName+"還沒有鎖,開始主動(dòng)獲取鎖......");lock.lock();// 主動(dòng)獲取鎖System.out.println(tName+"獲取到鎖!");try {int n = 1 / 0;System.out.println(n);for (int i = 0; i < 10; i++) {System.out.println(tName+":" + i);}} catch (Exception e) {System.out.println(tName+"出錯(cuò)了!!!");}finally {//lock.unlock();}}}.start();new Thread() {@Overridepublic void run() {Lock lock = new ReentrantLock();String tName=Thread.currentThread().getName();System.out.println(tName+"還沒有鎖,開始主動(dòng)獲取鎖......");lock.lock();// 主動(dòng)獲取鎖,此時(shí)獲取不到鎖,因?yàn)榫€程1出錯(cuò)了,lock()不會(huì)主動(dòng)釋放鎖,線程1又沒有釋放鎖,所以就死鎖了。System.out.println(tName+"tName獲取到鎖!");for (int i = 0; i < 10; i++) {System.out.println(tName+":" + i);}}}.start();}
運(yùn)行結(jié)果:
Thread-0還沒有鎖,開始主動(dòng)獲取鎖......
Thread-0獲取到鎖!
Thread-0出錯(cuò)了!!!
Thread-1還沒有鎖,開始主動(dòng)獲取鎖......
Thread-1tName獲取到鎖!
Thread-1:0
Thread-1:1
Thread-1:2
Thread-1:3
Thread-1:4
Thread-1:5
Thread-1:6
Thread-1:7
Thread-1:8
Thread-1:9
鎖對象是同一個(gè)
兩個(gè)線程的鎖對象是同一個(gè),當(dāng)獲取鎖的線程沒有釋放鎖的時(shí)候,就產(chǎn)生了死鎖,其他線程只能無止盡地等待
@Testpublic void testLock2() {//兩個(gè)線程的鎖對象是同一個(gè),當(dāng)獲取鎖的線程沒有釋放鎖的時(shí)候,就產(chǎn)生了死鎖,其他線程只能無止盡地等待Lock lock = new ReentrantLock();new Thread() {@Overridepublic void run() {String tName=Thread.currentThread().getName();System.out.println(tName+"還沒有鎖,開始主動(dòng)獲取鎖......");lock.lock();// 主動(dòng)獲取鎖System.out.println(tName+"獲取到鎖!");try {int n = 1 / 0;System.out.println(n);for (int i = 0; i < 10; i++) {System.out.println(tName+":" + i);}} catch (Exception e) {System.out.println(tName+"出錯(cuò)了!!!");}finally {}}}.start();new Thread() {@Overridepublic void run() {String tName=Thread.currentThread().getName();System.out.println(tName+"還沒有鎖,開始主動(dòng)獲取鎖......");lock.lock();// 主動(dòng)獲取鎖,此時(shí)獲取不到鎖,因?yàn)橹俺鲥e(cuò)了,lock()不會(huì)主動(dòng)釋放鎖,線程又沒有釋放鎖,所以就死鎖了。System.out.println(tName+"tName獲取到鎖!");for (int i = 0; i < 10; i++) {System.out.println(tName+":" + i);}}}.start();}
Thread-0還沒有鎖,開始主動(dòng)獲取鎖......
Thread-0獲取到鎖!
Thread-0出錯(cuò)了!!!
Thread-1還沒有鎖,開始主動(dòng)獲取鎖......
釋放鎖
兩個(gè)線程的鎖對象是同一個(gè),當(dāng)獲取鎖的線程沒有釋放鎖的時(shí)候,就產(chǎn)生了死鎖,其他線程只能無止盡地等待
在try-finally里不管是順利執(zhí)行完,還是出錯(cuò),都要主動(dòng)釋放鎖,則其他線程就能獲取到
@Testpublic void testLock3() {//兩個(gè)線程的鎖對象是同一個(gè),當(dāng)獲取鎖的線程沒有釋放鎖的時(shí)候,就產(chǎn)生了死鎖,其他線程只能無止盡地等待//在try-finally里不管是順利執(zhí)行完,還是出錯(cuò),都要主動(dòng)釋放鎖,則其他線程就能獲取到Lock lock = new ReentrantLock();new Thread() {@Overridepublic void run() {String tName=Thread.currentThread().getName();System.out.println(tName+"還沒有鎖,開始主動(dòng)獲取鎖......");lock.lock();// 主動(dòng)獲取鎖System.out.println(tName+"獲取到鎖!");try {int n = 1 / 0;System.out.println(n);for (int i = 0; i < 10; i++) {System.out.println(tName+":" + i);}} catch (Exception e) {System.out.println(tName+"出錯(cuò)了!!!");}finally {System.out.println(tName+"釋放鎖!!");lock.unlock();}}}.start();new Thread() {@Overridepublic void run() {String tName=Thread.currentThread().getName();System.out.println(tName+"還沒有鎖,開始主動(dòng)獲取鎖......");lock.lock();// 主動(dòng)獲取鎖,此時(shí)獲取不到鎖,因?yàn)橹俺鲥e(cuò)了,lock()不會(huì)主動(dòng)釋放鎖,線程又沒有釋放鎖,所以就死鎖了。System.out.println(tName+"tName獲取到鎖!");for (int i = 0; i < 10; i++) {System.out.println(tName+":" + i);}}}.start();}
Thread-0還沒有鎖,開始主動(dòng)獲取鎖......
Thread-0獲取到鎖!
Thread-0出錯(cuò)了!!!
Thread-0釋放鎖!!
Thread-1還沒有鎖,開始主動(dòng)獲取鎖......
Thread-1tName獲取到鎖!
Thread-1:0
Thread-1:1
Thread-1:2
Thread-1:3
Thread-1:4
Thread-1:5
Thread-1:6
Thread-1:7
Thread-1:8
Thread-1:9
總結(jié)
以上是生活随笔為你收集整理的Lock的lock()方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Tomcat提示“XDB 的服务器 lo
- 下一篇: UNION 和UNION ALL 的区别