新聞中心
Java線程通信在我們使用的時候需要長期的學(xué)習(xí),在學(xué)習(xí)的過程中我們就要詳細(xì)的看看如何才能更好的掌握相關(guān)語言的使用問題。首先我們來看看具體的相關(guān)問題處理。

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名注冊、虛擬空間、營銷軟件、網(wǎng)站建設(shè)、奉賢網(wǎng)站維護(hù)、網(wǎng)站推廣。
使當(dāng)前Java線程通信(即調(diào)用該方法的線程)暫停執(zhí)行一段時間,讓其他線程有機(jī)會繼續(xù)執(zhí)行,但它并不釋放對象鎖。也就是如果有Synchronized同步塊,其他線程仍然不同訪問共享數(shù)據(jù)。注意該方法要捕獲異常#t#
比如有兩個線程同時執(zhí)行(沒有Synchronized),一個線程優(yōu)先級為MAX_PRIORITY,另一個為MIN_PRIORITY,如果沒有Sleep()方法,只有高優(yōu)先級的線程執(zhí)行完成后,低優(yōu)先級的線程才能執(zhí)行;但當(dāng)高優(yōu)先級的線程sleep(5000)后,低優(yōu)先級就有機(jī)會執(zhí)行了。
總之,sleep()可以使低優(yōu)先級的Java線程通信得到執(zhí)行的機(jī)會,當(dāng)然也可以讓同優(yōu)先級、高優(yōu)先級的線程有執(zhí)行的機(jī)會。
join()
join()方法使調(diào)用該方法的Java線程通信在此之前執(zhí)行完畢,也就是等待調(diào)用該方法的線程執(zhí)行完畢后再往下繼續(xù)執(zhí)行。注意該方法也要捕獲異常。
yield()
它與sleep()類似,只是不能由用戶指定暫停多長時間,并且yield()方法只能讓同優(yōu)先級的線程有執(zhí)行的機(jī)會。
wait()和notify()、notifyAll()
這三個方法用于協(xié)調(diào)多個Java線程通信對共享數(shù)據(jù)的存取,所以必須在Synchronized語句塊內(nèi)使用這三個方法。前面說過Synchronized這個關(guān)鍵字用于保護(hù)共享數(shù)據(jù),阻止其他線程對共享數(shù)據(jù)的存取。但是這樣程序的流程就很不靈活了,如何才能在當(dāng)前線程還沒退出Synchronized數(shù)據(jù)塊時讓其他線程也有機(jī)會訪問共享數(shù)據(jù)呢?此時就用這三個方法來靈活控制。
wait()方法使當(dāng)前線程暫停執(zhí)行并釋放對象鎖標(biāo)志,讓其他線程可以進(jìn)入Synchronized數(shù)據(jù)塊,當(dāng)前線程被放入對象等待池中。當(dāng)調(diào)用 notify()方法后,將從對象的等待池中移走一個任意的線程并放到鎖標(biāo)志等待池中,只有鎖標(biāo)志等待池中的線程能夠獲取鎖標(biāo)志;如果鎖標(biāo)志等待池中沒有Java線程通信,則notify()不起作用。
notifyAll()則從對象等待池中移走所有等待那個對象的線程并放到鎖標(biāo)志等待池中。
網(wǎng)站標(biāo)題:Java線程通信簡單調(diào)試方法介紹
轉(zhuǎn)載來源:http://www.dlmjj.cn/article/dpephee.html


咨詢
建站咨詢
