久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Java多線程基礎 線程的等待與喚醒

瀏覽:73日期:2022-09-05 14:18:41

題圖:花啡,豆是買咖啡機送的,花是上周陽朔旅游買的桂花,給它起了個名字,叫 Sunday。

咖啡味淡了一點點,多了一份桂花的清香。

本篇我們來研究一下 wait() notify() notifyAll() 。

DEMO1: wait() 與 notify()

public class Test { static class ThreadOne extends Thread {private Callback mCallback;@Overridepublic void run() { work(); if (mCallback != null) {mCallback.onResult(false); }}// 耗時 3sprivate void work() { System.out.println(' 正在查詢數據庫 1'); long startTime = System.currentTimeMillis(); while (true) {if (System.currentTimeMillis() - startTime < 3000) { continue;}break; }}public void setCallback(Callback callback) { mCallback = callback;}public interface Callback { void onResult(boolean result);} } static class ThreadTest extends Thread {private Object mLock = new Object();private ThreadOne mThreadOne;@Overridepublic void run() { workOne(); System.out.println(' 根據結果繼續做其他事情 ');}private void workOne() { mThreadOne = new ThreadOne(); mThreadOne.setCallback(new ThreadOne.Callback() {@Overridepublic void onResult(boolean result) { System.out.println(' 查詢數據庫 1 結束,:' + (result ? ' 有數據 ' : ' 無數據 ')); synchronized (mLock) {mLock.notify();System.out.println('--ThreadTest 結束等待 --'); }} }); mThreadOne.start(); try {synchronized (mLock) { System.out.println('--ThreadTest 進入等待 --'); mLock.wait();} } catch (InterruptedException e) {e.printStackTrace(); }} } public static void main(String[] var0) {ThreadTest threadTest = new ThreadTest();threadTest.start(); }}

DEMO1 輸出:

--ThreadTest 進入等待--正在查詢數據庫 1查詢數據庫 1 結束,: 無數據--ThreadTest 結束等待--根據結果繼續做其他事情

注意:

使用 wait() 和 notify() 必須在獲得同步鎖后才能調用,若直接調用會報 java.lang.IllegalMonitorStateException 錯誤,因為狀態由同步鎖保護。

wait() 不同于 sleep() 的是 wait() 會釋放同步鎖。

因為 wait() 和 notify() 是基于同步鎖實現的,每個對象都有自己的同步鎖,所以 wait() 和 notify() 是 Object 的方法,而不是 Thread。

DEMO2,wait() 與 notifyAll():

public class Test { private static Object mLock = new Object(); static class MyThread extends Thread {String mName;Callback mCallback;public MyThread(String name){ mName = name;}@Overridepublic void run() { work(); if (mCallback != null) {mCallback.onResult(false); }}// 耗時 3sprivate void work() { System.out.println(mName + ' 等待 '); try {synchronized (mLock) { mLock.wait();} } catch (InterruptedException e) {e.printStackTrace(); }}public void setCallback(Callback callback) { mCallback = callback;}public interface Callback { void onResult(boolean result);} } static class ThreadTest extends Thread {@Overridepublic void run() { work('db1'); work('db2'); work('db3'); try {sleep(2000); } catch (InterruptedException e) {e.printStackTrace(); } synchronized (mLock) {System.out.println(' 喚醒全部 ');mLock.notifyAll(); }}private void work(String name) { final MyThread myThread = new MyThread(name); myThread.setCallback(new MyThread.Callback() {@Overridepublic void onResult(boolean result) { System.out.println(myThread.mName + ' 回來了 ');} }); myThread.start();} } public static void main(String[] var0) {ThreadTest threadTest = new ThreadTest();threadTest.start(); }}

DEMO2 輸出:

db1 等待db3 等待db2 等待喚醒全部db3 回來了db1 回來了db2 回來了

同一個對象的 wait() 方法可多次在不同的線程中調用,可讓不同的線程進入等待(阻塞),可以一個一個 notify(),也可以調用 notifyAll() 一次性全部喚醒。

來自:http://hackeris.me/2017/05/07/thread_base_1/

標簽: Java
相關文章:
主站蜘蛛池模板: 亚洲一区二区三区四区在线观看 | 久久精品一区二区三区不卡牛牛 | 中文字幕二区 | 97久久精品午夜一区二区 | a欧美| 国产精品人人做人人爽 | 亚洲日本中文 | 国产亚洲女人久久久久毛片 | 亚洲精品三级 | 精品网站999www | 国产在线观看免费av | 久久综合一区 | 久草热8精品视频在线观看 欧美全黄 | 午夜a级理论片915影院 | 日韩一区免费观看 | 国产色片在线 | 色视频在线免费观看 | 91高清在线| 美女视频一区 | 国产精品一区二区三区四区五区 | 久久久久国产精品 | 久久香蕉国产视频 | 免费av电影观看 | 狠狠操网站 | 国产成人精品一区二 | 国产精品欧美一区二区三区 | 久久免费精品视频 | 久久精品国产99国产 | 一区二区免费在线观看 | av高清在线免费观看 | 久草毛片 | 欧美日韩精品一区二区 | 免费观看一级特黄欧美大片 | 人妖av | 日韩欧美精品一区二区三区 | 精品国产一区二区三区在线观看 | 国内自拍视频在线观看 | 午夜精品亚洲日日做天天做 | 精品成人在线 | 91在线精品一区二区 | 久久久久久一区 |