概述
lockInterruptibly()方法比較特殊,當通過這個方法去獲取鎖時,如果其他線程正在等待獲取鎖,則這個線程能夠響應中斷,即中斷線程的等待狀態。也就使說,當兩個線程同時通過lock.lockInterruptibly()想獲取某個鎖時,假若此時線程A獲取到了鎖,而線程B只有等待,那么對線程B調用threadB.interrupt()方法能夠中斷線程B的等待過程。
【注意是:等待的那個線程B可以被中斷,不是正在執行的A線程被中斷】
代碼
有關線程中斷的請見:http://blog.csdn.net/zengmingen/article/details/53259966
BussinessClass 業務類代碼
package multithreading.lock;import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;public class BussinessClass {private Lock lock = new ReentrantLock();// 業務方法public void bFuction() {String tName = Thread.currentThread().getName();try {System.out.println(tName + "-開始獲取鎖..........");lock.lockInterruptibly();System.out.println(tName + "-獲取到鎖了!!!!");System.out.println(tName + "-睡覺了,睡個30秒!");Thread.sleep(30000);System.out.println(tName + "-睡醒了,干活!");for (int i = 0; i < 5; i++) {System.out.println(tName + ":" + i);}} catch (Exception e) {System.out.println(tName+"-我好像被中斷了!");e.printStackTrace();}finally{lock.unlock();System.out.println(tName + "-釋放了鎖");}}}
package multithreading.lock;import org.junit.Test;public class TestInterruptibly {@Testpublic void testInterruptibly() throws Exception{BussinessClass bc=new BussinessClass();Thread t0=new Thread(){@Overridepublic void run() {bc.bFuction();}};Thread t1=new Thread(){@Overridepublic void run() {bc.bFuction();}};String tName=Thread.currentThread().getName();System.out.println(tName+"-啟動t0!");t0.start();System.out.println(tName+"-我等個5秒,再啟動t1");Thread.sleep(5000);System.out.println(tName+"-啟動t1");t1.start();System.out.println(tName+"-t1獲取不到鎖,t0這貨睡覺了,沒釋放,我等個5秒!");Thread.sleep(5000);System.out.println(tName+"-等了5秒了,不等了,把t1中斷了!");t1.interrupt();Thread.sleep(Long.MAX_VALUE);}}
運行結果
main-啟動t0!
main-我等個5秒,再啟動t1
Thread-0-開始獲取鎖..........
Thread-0-獲取到鎖了!!!!
Thread-0-睡覺了,睡個30秒!
main-啟動t1
main-t1獲取不到鎖,t0這貨睡覺了,沒釋放,我等個5秒!
Thread-1-開始獲取鎖..........
main-等了5秒了,不等了,把t1中斷了!
java.lang.InterruptedException
Thread-1-我好像被中斷了!
at java.util.concurrent.locks.AbstractQueuedSynchronizer.doAcquireInterruptibly(Unknown Source)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquireInterruptibly(Unknown Source)
at java.util.concurrent.locks.ReentrantLock.lockInterruptibly(Unknown Source)
at multithreading.lock.BussinessClass.bFuction(BussinessClass.java:15)
at multithreading.lock.TestInterruptibly$2.run(TestInterruptibly.java:23)
Exception in thread "Thread-1" java.lang.IllegalMonitorStateException
at java.util.concurrent.locks.ReentrantLock$Sync.tryRelease(Unknown Source)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.release(Unknown Source)
at java.util.concurrent.locks.ReentrantLock.unlock(Unknown Source)
at multithreading.lock.BussinessClass.bFuction(BussinessClass.java:28)
at multithreading.lock.TestInterruptibly$2.run(TestInterruptibly.java:23)
Thread-0-睡醒了,干活!
Thread-0:0
Thread-0:1
Thread-0:2
Thread-0:3
Thread-0:4
Thread-0-釋放了鎖
main-我等個5秒,再啟動t1
Thread-0-開始獲取鎖..........
Thread-0-獲取到鎖了!!!!
Thread-0-睡覺了,睡個30秒!
main-啟動t1
main-t1獲取不到鎖,t0這貨睡覺了,沒釋放,我等個5秒!
Thread-1-開始獲取鎖..........
main-等了5秒了,不等了,把t1中斷了!
java.lang.InterruptedException
Thread-1-我好像被中斷了!
at java.util.concurrent.locks.AbstractQueuedSynchronizer.doAcquireInterruptibly(Unknown Source)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.acquireInterruptibly(Unknown Source)
at java.util.concurrent.locks.ReentrantLock.lockInterruptibly(Unknown Source)
at multithreading.lock.BussinessClass.bFuction(BussinessClass.java:15)
at multithreading.lock.TestInterruptibly$2.run(TestInterruptibly.java:23)
Exception in thread "Thread-1" java.lang.IllegalMonitorStateException
at java.util.concurrent.locks.ReentrantLock$Sync.tryRelease(Unknown Source)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.release(Unknown Source)
at java.util.concurrent.locks.ReentrantLock.unlock(Unknown Source)
at multithreading.lock.BussinessClass.bFuction(BussinessClass.java:28)
at multithreading.lock.TestInterruptibly$2.run(TestInterruptibly.java:23)
Thread-0-睡醒了,干活!
Thread-0:0
Thread-0:1
Thread-0:2
Thread-0:3
Thread-0:4
Thread-0-釋放了鎖
-------------
更多的Java,Angular,Android,大數據,J2EE,Python,數據庫,Linux,Java架構師,:
http://www.cnblogs.com/zengmiaogen/p/7083694.html