Java線程同步阻塞, sleep(), suspend(), resume(), yield(), wait(), notify()

來源:互聯網
上載者:User

 

為瞭解決對共用儲存區的存取違規,Java 引入了同步機制。但顯然不夠,因為在任意時刻所要求的資源不一定已經準備好了被訪問,反過來,同一時刻準備好了的資源也可能不止一個。

 

 

為解決存取控制問題,Java 引入阻塞機制。阻塞指的是暫停一個Java線程同步的執行以等待某個條件發生(如某資源就緒)。

 

 

sleep():允許指定以毫秒為單位的一段時間作為參數,它使得線程在指定的時間內進入阻塞狀態,不能得到CPU 時 間,指定的時間一過,線程重新進入可執行狀態。典型地,sleep() 被用在等待某個資源就緒的情形:測試發現條件不滿足後,讓線程阻塞一段時間後重新 測試,直到條件滿足為止。

 

suspend()&resume():兩個方法配套使用,suspend()使得線程進 入阻塞狀態,並且不會自動回復,必須其對應的resume() 被調用,才能使得線程重新進入可執行狀態。典型 地,suspend() 和 resume() 被用在等待另一個線程產生的結果的情形:測試發現結果還沒有產生後,讓線程阻塞,另一個線程產生了結果 後,調用 resume() 使其恢複。

 

yield():yield() 使得線程放棄當前分得的 CPU 時間,但是不使線程阻塞,即線程仍處於可執行狀態,隨時可能再次分得 CPU 時間。調用 yield() 的效果等價於發送器認為該Java線程同步已執行了足夠的時間從而轉到另一個線程。

 

wait()&notify():兩個方法配套使用,wait() 使得線程進入阻塞狀態,它有兩種形式,一種允許指定以毫秒為單位的 一段時間作為參數,另一種沒有參數,前者當對應的 notify() 被調用或者超出指定時間時Java線程同步重新進入可執行狀態,後者則必須對應 的 notify() 被調用。小提示:(1)使用時必須synchronized,否則立即拋異常。(2)wait()&notify()是對象的方法。

 

初看起來它們與 suspend() 和 resume() 方法對沒有什麼分別,但是事實上它們是截然不同的。區別的核心在於,前面敘述的所有方法,阻塞時都不會釋放佔用的鎖(如果佔用了的話),而這一對方法則會釋放佔用的鎖

 

 

在synchronized代碼被執行期間,線程可以調用對象的wait()方法,釋放對象鎖標誌,進入等待狀態,並且可以調用notify()或者notifyAll()方法通知正在等待的其他線程。notify()通知等待隊列中的第一個線程,notifyAll()通知的是等待隊列中的所有線程。

 

 

http://www.diybl.com/course/3_program/java/javajs/20100705/338301.html

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.