Java-線程間通訊小結

1)方法wait的做用是使當前執行代碼的線程進行等待,將當前線程置入預執行隊列,而且在wait所在代碼行處中止執行,直到接到通知或者中斷。在wait以前,要得到一個對象鎖,即wait只能在同步方法/塊中使用,執行wait以後當即釋放鎖。wait狀態不能被interrupt,會拋異常。線程

2)notify隨機喚醒等待隊列中等待同一共享資源的線程。notify也要得到一個對象鎖,即notify也只能在同步方法/塊中使用,執行notify以後,線程繼續執行後面的代碼,直到所有完成,纔會釋放鎖。以後由線程規劃器挑出一個等待狀態的線程對其發出notify,並使其得到對象鎖,讓其執行wait以後的語句,再釋放掉鎖。對象

3)notifyAll喚醒全部等待的線程隊列

4)wait(long)等待某一個時間內是否有線程對鎖進行喚醒,若是超過這個時間就自動喚醒ip

5)生產者、消費者模式原來都是基於wait/notify原理資源

6)管道流pipeStream是一種特殊的流,用於在不一樣線程間直接傳送數據。一個線程發送數據到輸出管道,另外一個線程從輸入管道中讀數據,經過使用管道,實現不一樣線程間的通訊。Java提供了四個類來使線程間進行通訊:PipedInputStream、PipedOutputStream、PipedReader、PipedWriter。使用方法:在外部定義一個PipedInputStream和一個PipedOutputStream,而後讓PipedOutputStream鏈接(connect)PipedInputStream,而後將這兩個流分別給到輸入數據和輸出數據的線程,兩個線程之間就能夠傳輸字節或者字符流了get

7)join的做用是等待線程對象銷燬。主線程建立子線程,若子線程耗時嚴重,主線程將會先於子線程完成。這時若是主線程想等待子線程執行完成以後再結束,好比獲取子線程處理完成的數據,這時就用到了join。主線程啓動子線程a,而後a.join就會一直阻塞在那,直到a運行完成同步

8)線程join時不能被interrupt,會拋異常;join(long)設置等待時間,結束後也會釋放鎖(但sleep不會釋放鎖)it

9)ThreadLocal解決的是每一個線程綁定本身的值,每一個線程均可以執行ThreadLocal.set(object)將本身的值放入,再經過get()獲取本身的值。ThreadLocal解決的是變量在不一樣線程間的隔離性,也就是不一樣線程擁有本身的值。pip

相關文章
相關標籤/搜索