(转) Java线程同步阻塞, sleep(), suspend(), resume(), yield(), wait(), notify()
為了解決對共享存儲區(qū)的訪問沖突,Java 引入了同步機(jī)制。但顯然不夠,因?yàn)樵谌我鈺r刻所要求的資源不一定已經(jīng)準(zhǔn)備好了被訪問,反過來,同一時刻準(zhǔn)備好了的資源也可能不止一個。
為解決訪問控制問題,Java 引入阻塞機(jī)制。阻塞指的是暫停一個Java線程同步的執(zhí)行以等待某個條件發(fā)生(如某資源就緒)。
?
sleep():允許指定以毫秒為單位的一段時間作為參數(shù),它使得線程在指定的時間內(nèi)進(jìn)入阻塞狀態(tài),不能得到CPU 時 間,指定的時間一過,線程重新進(jìn)入可執(zhí)行狀態(tài)。典型地,sleep() 被用在等待某個資源就緒的情形:測試發(fā)現(xiàn)條件不滿足后,讓線程阻塞一段時間后重新 測試,直到條件滿足為止。
?
suspend()&resume():兩個方法配套使用,suspend()使得線程進(jìn) 入阻塞狀態(tài),并且不會自動恢復(fù),必須其對應(yīng)的resume() 被調(diào)用,才能使得線程重新進(jìn)入可執(zhí)行狀態(tài)。典型 地,suspend() 和 resume() 被用在等待另一個線程產(chǎn)生的結(jié)果的情形:測試發(fā)現(xiàn)結(jié)果還沒有產(chǎn)生后,讓線程阻塞,另一個線程產(chǎn)生了結(jié)果 后,調(diào)用 resume() 使其恢復(fù)。
?
yield():yield() 使得線程放棄當(dāng)前分得的 CPU 時間,但是不使線程阻塞,即線程仍處于可執(zhí)行狀態(tài),隨時可能再次分得 CPU 時間。調(diào)用 yield() 的效果等價(jià)于調(diào)度程序認(rèn)為該Java線程同步已執(zhí)行了足夠的時間從而轉(zhuǎn)到另一個線程。
?
wait()¬ify():兩個方法配套使用,wait() 使得線程進(jìn)入阻塞狀態(tài),它有兩種形式,一種允許指定以毫秒為單位的 一段時間作為參數(shù),另一種沒有參數(shù),前者當(dāng)對應(yīng)的 notify() 被調(diào)用或者超出指定時間時Java線程同步重新進(jìn)入可執(zhí)行狀態(tài),后者則必須對應(yīng) 的 notify() 被調(diào)用。小提示:(1)使用時必須synchronized,否則立即拋異常。(2)wait()¬ify()是對象的方法。
初看起來它們與 suspend() 和 resume() 方法對沒有什么分別,但是事實(shí)上它們是截然不同的。區(qū)別的核心在于,前面敘述的所有方法,阻塞時都不會釋放占用的鎖(如果占用了的話),而這一對方法則會釋放占用的鎖。
在synchronized代碼被執(zhí)行期間,線程可以調(diào)用對象的wait()方法,釋放對象鎖標(biāo)志,進(jìn)入等待狀態(tài),并且可以調(diào)用notify()或者notifyAll()方法通知正在等待的其他線程。notify()通知等待隊(duì)列中的第一個線程,notifyAll()通知的是等待隊(duì)列中的所有線程。
轉(zhuǎn)載于:https://www.cnblogs.com/tiantianlang/p/7514628.html
總結(jié)
以上是生活随笔為你收集整理的(转) Java线程同步阻塞, sleep(), suspend(), resume(), yield(), wait(), notify()的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 隐藏Nginx或Apache以及PHP的
- 下一篇: 阿里云linux centos 一键部署