Java-執行緒間通訊小結

振宇要低調發表於2018-10-25

1)方法wait的作用是使當前執行程式碼的執行緒進行等待,將當前執行緒置入預執行佇列,並且在wait所在程式碼行處停止執行,直到接到通知或者中斷。在wait之前,要獲得一個物件鎖,即wait只能在同步方法/塊中使用,執行wait之後立即釋放鎖。wait狀態不能被interrupt,會拋異常。

2)notify隨機喚醒等待佇列中等待同一共享資源的執行緒。notify也要獲得一個物件鎖,即notify也只能在同步方法/塊中使用,執行notify之後,執行緒繼續執行後面的程式碼,直到全部完成,才會釋放鎖。之後由執行緒規劃器挑出一個等待狀態的執行緒對其發出notify,並使其獲得物件鎖,讓其執行wait之後的語句,再釋放掉鎖。

3)notifyAll喚醒所有等待的執行緒

4)wait(long)等待某一個時間內是否有執行緒對鎖進行喚醒,如果超過這個時間就自動喚醒

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

6)管道流pipeStream是一種特殊的流,用於在不同執行緒間直接傳送資料。一個執行緒傳送資料到輸出管道,另一個執行緒從輸入管道中讀資料,通過使用管道,實現不同執行緒間的通訊。Java提供了四個類來使執行緒間進行通訊:PipedInputStream、PipedOutputStream、PipedReader、PipedWriter。使用方法:在外部定義一個PipedInputStream和一個PipedOutputStream,然後讓PipedOutputStream連線(connect)PipedInputStream,然後將這兩個流分別給到輸入資料和輸出資料的執行緒,兩個執行緒之間就可以傳輸位元組或者字元流了

7)join的作用是等待執行緒物件銷燬。主執行緒建立子執行緒,若子執行緒耗時嚴重,主執行緒將會先於子執行緒完成。這時如果主執行緒想等待子執行緒執行完成之後再結束,比如獲取子執行緒處理完成的資料,這時就用到了join。主執行緒啟動子執行緒a,然後a.join就會一直阻塞在那,直到a執行完成

8)執行緒join時不能被interrupt,會拋異常;join(long)設定等待時間,結束後也會釋放鎖(但sleep不會釋放鎖)

9)ThreadLocal解決的是每個執行緒繫結自己的值,每個執行緒都可以執行ThreadLocal.set(object)將自己的值放入,再通過get()獲取自己的值。ThreadLocal解決的是變數在不同執行緒間的隔離性,也就是不同執行緒擁有自己的值。

相關文章