Java-线程间通信小结
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解決的是變量在不同線程間的隔離性,也就是不同線程擁有自己的值。
總結
以上是生活随笔為你收集整理的Java-线程间通信小结的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 1024活动第三天
- 下一篇: ngnix的upstream模块配置详解