java併發包下的LockSupport

java.util.concurrent.locks.LockSupportjava

概念:用LockSupport來實現線程的阻塞和喚醒。


阻塞線程的方法:
	public static void park():阻塞當前線程,只有調用unpark()方法或者當前線程被中斷,該方法纔會返回。
	public static void parkNanos(long nanos)
	public static void parkUntil(long deadline)

	
喚醒線程的方法:
	public static void unpark(Thread thread):喚醒阻塞的線程。

	
在Java6中,LockSupport增長了3個方法:
	public static void park(Object blocker)
	public static void parkNanos(Object blocker, long nanos)
	public static void parkUntil(Object blocker, long deadline)

	參數:
		blocker:用來標識當前線程正在等待的對象(即阻塞對象),主要用於排查問題和系統監控。

	在線程dump時,帶blocker參數的park()方法比不帶blocker參數的park()方法多出如下內容(即指出了阻塞對象的類型):
		- parking to wait for <0x000...> ( com.jxn.test.TestLockSupport)
		
	說明:
		1)當線程(因使用synchronized關鍵字)阻塞在一個對象上時,經過線程dump可以查看到該線程的阻塞對象,從而能夠方便地定位問題。
		2)使用LockSupport中不帶blocker參數的park()方法來阻塞對象時,經過線程dump沒法看到該線程的阻塞對象;故在java6中,提供了帶blocker參數的park()方法來解決這一問題。
相關文章
相關標籤/搜索