Java線程如何才能管理好自己的“小弟”
Java線程需要大家學習知識有很多,我們在不斷學習的過程中就會體會到Java線程中繁多的分支,下面我們就來看看幾個具有代表性的分支,希望大家有所收獲。
使當前線程(即調用該方法的Java線程)暫停執行一段時間,讓其他線程有機會繼續執行,但它并不釋放對象鎖。也就是如果有Synchronized同步塊,其他線程仍然不同訪問共享數據。注意該方法要捕獲異常。#t#
比如有兩個線程同時執行(沒有Synchronized),一個Java線程優先級為MAX_PRIORITY,另一個為MIN_PRIORITY,如果沒有Sleep()方法,只有高優先級的線程執行完成后,低優先級的線程才能執行;但當高優先級的線程sleep(5000)后,低優先級就有機會執行了。
總之,sleep()可以使低優先級的Java線程得到執行的機會,當然也可以讓同優先級、高優先級的線程有執行的機會。
join()
join()方法使調用該方法的線程在此之前執行完畢,也就是等待調用該方法的線程執行完畢后再往下繼續執行。注意該方法也要捕獲異常。
yield()
它與sleep()類似,只是不能由用戶指定暫停多長時間,并且yield()方法只能讓同優先級的Java線程有執行的機會。
wait()和notify()、notifyAll()
這三個方法用于協調多個Java線程對共享數據的存取,所以必須在Synchronized語句塊內使用這三個方法。前面說過Synchronized這個關鍵字用于保護共享數據,阻止其他線程對共享數據的存取。但是這樣程序的流程就很不靈活了,如何才能在當前線程還沒退出Synchronized數據塊時讓其他線程也有機會訪問共享數據呢?此時就用這三個方法來靈活控制。
wait()方法使當前線程暫停執行并釋放對象鎖標志,讓其他線程可以進入Synchronized數據塊,當前線程被放入對象等待池中。當調用 notify()方法后,將從對象的等待池中移走一個任意的線程并放到鎖標志等待池中,只有鎖標志等待池中的Java線程能夠獲取鎖標志;如果鎖標志等待池中沒有線程,則notify()不起作用。
notifyAll()則從對象等待池中移走所有等待那個對象的Java線程并放到鎖標志等待池中。