java线程阻塞唤醒的四种方式
java在多線程情況下,經常會使用到線程的阻塞與喚醒,這里就為大家簡單介紹一下以下幾種阻塞/喚醒方式與區別,不做詳細的介紹與代碼分析
Java廢棄 suspend() 去掛起線程的原因,是因為 suspend() 在導致線程暫停的同時,并不會去釋放任何鎖資源。其他線程都無法訪問被它占用的鎖。直到對應的線程執行 resume() 方法后,被掛起的線程才能繼續,從而其它被阻塞在這個鎖的線程才可以繼續執行。
但是,如果 resume() 操作出現在 suspend() 之前執行,那么線程將一直處于掛起狀態,同時一直占用鎖,這就產生了死鎖。而且,對于被掛起的線程,它的線程狀態居然還是 Runnable。
wait與notify必須配合synchronized使用,因為調用之前必須持有鎖,wait會立即釋放鎖,notify則是同步塊執行完了才釋放
Condition類提供,而Condition對象由new ReentLock().newCondition()獲得,與wait和notify相同,因為使用Lock鎖后無法使用wait方法
LockSupport是一個非常方便實用的線程阻塞工具,它可以在線程任意位置讓線程阻塞。和Thread.suspenf()相比,它彌補了由于resume()在前發生,導致線程無法繼續執行的情況。和Object.wait()相比,它不需要先獲得某個對象的鎖,也不會拋出IException異常。可以喚醒指定線程。
總結
-
wait與await區別:
- wait與notify必須配合synchronized使用,因為調用之前必須持有鎖,wait會立即釋放鎖,notify則是同步塊執行完了才釋放
- 因為Lock沒有使用synchronized機制,故無法使用wait方法區操作多線程,所以使用了Condition的await來操作
-
Lock實現主要是基于AQS,而AQS實現則是基于LockSupport,所以說LockSupport更底層,所以使用park效率會高一些
更多Java優質文章,請關注豬哥微信公眾號:豬哥Java!
總結
以上是生活随笔為你收集整理的java线程阻塞唤醒的四种方式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 高并发级别简述
- 下一篇: RSA算法原理——(1)目前常见加密算法