多线程同步中sleep与wait区别
生活随笔
收集整理的這篇文章主要介紹了
多线程同步中sleep与wait区别
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
目錄
1、函數
2、多線程
1、函數
?wait是Object的一個函數,指線程處于進入等待狀態,此時線程不占用任何資源,不增加時間限制。wait可以被notify和notifyAll函數喚醒(這兩個也是Object的函數)。
sleep則是Thread的一個函數,指線程被調用時,占著CPU不工作.此時,系統的CPU部分資源被占用,其他線程無法進入,會增加時間限制。
所以
sleep(100L)意思為:占用CPU,線程休眠100毫秒
wait(100L)意思為:不占用CPU,線程等待100毫秒
注意:wait和sleep最終都是調用native函數。
2、多線程
使用多線程就沒法繞過同步問題,而wait和sleep對于同步鎖也有不同的效果 (1)在使用上,調用obj的wait和notify函數前必須獲取對象鎖,即在synchronized(obj){...}代碼塊中。 (2)如果都在synchronized代碼塊中,wait(obj)函數可以釋放鎖,而sleep函數則不釋放鎖。 在wait釋放鎖這里有一個場景: 有兩個線程A和B,在A線程中有如下代碼: synchronized(mLock){...mLock.wait();... }這樣在synchronized處獲取對象鎖,當執行到wait函數時,線程A進入等待狀態,并且釋放對象鎖。
在B線程中有如下代碼: synchronized(mLock){...mLock.notify();... }當A的wait函數釋放鎖時,B線程的synchronized獲取了對象鎖,開始執行代碼。
當執行到notify函數時,喚醒A線程。但是這時由于B的synchronized代碼塊未執行完,所以未釋放鎖。所以先執行B線程notify后面的代碼,B的synchronized代碼執行完后釋放鎖,A線程獲取鎖并執行wait之后的代碼。
(注意,如果有多個wait狀態的obj,notify函數只能喚醒其中一個,是由JVM決定的,而notifyAll可以喚醒所有的)
測試代碼如下: Thread a = new Thread(new Runnable() {@Overridepublic void run() {synchronized (mLock){Log.e("sss", "a 1");try {mLock.wait();} catch (InterruptedException e) {e.printStackTrace();}Log.e("sss", "a 2");}} }); Thread b = new Thread(new Runnable() {@Overridepublic void run() {synchronized (mLock){Log.e("sss", "b 1");try {mLock.notify();} catch (Exception e) {e.printStackTrace();}Log.e("sss", "b 2");}} }); a.start(); b.start(); 打印日志如下: 12-14 18:50:12.909 22793-22824/com.example.testapplication E/sss: a 1 12-14 18:50:12.909 22793-22825/com.example.testapplication E/sss: b 1 12-14 18:50:12.909 22793-22825/com.example.testapplication E/sss: b 2 12-14 18:50:12.909 22793-22824/com.example.testapplication E/sss: a 2?
總結
以上是生活随笔為你收集整理的多线程同步中sleep与wait区别的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ScrollView内嵌ListView
- 下一篇: Android中Intent/Bundl