国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Java 線程狀態(tài)和等待喚醒機(jī)制和線程池的實(shí)現(xiàn)

瀏覽:21日期:2022-09-03 14:51:37

1.概念

線程一共有6中狀態(tài),相互之間可以互相轉(zhuǎn)換。

Java 線程狀態(tài)和等待喚醒機(jī)制和線程池的實(shí)現(xiàn)

等待喚醒案例(線程之間的通信)

Java 線程狀態(tài)和等待喚醒機(jī)制和線程池的實(shí)現(xiàn)

實(shí)現(xiàn):

等待喚醒案例:線程之間的通信創(chuàng)建一個(gè)顧客線程(消費(fèi)者):告知老板要的包子的種類和數(shù)量,調(diào)用wait方法,放棄cpu的執(zhí)行,進(jìn)入到WAITING狀態(tài)(無限等待)創(chuàng)建一個(gè)老板線程(生產(chǎn)者):花了5秒做包子,做好包子之后,調(diào)用notify方法,喚醒顧客吃包子

注意:顧客和老板線程必須使用同步代碼塊包裹起來,保證等待和喚醒只能有一個(gè)在執(zhí)行同步使用的鎖對(duì)象必須保證唯一只有鎖對(duì)象才能調(diào)用wait和notify方法

Obejct類中的方法void wait()在其他線程調(diào)用此對(duì)象的 notify() 方法或 notifyAll() 方法前,導(dǎo)致當(dāng)前線程等待。void notify()喚醒在此對(duì)象監(jiān)視器上等待的單個(gè)線程。會(huì)繼續(xù)執(zhí)行wait方法之后的代碼

進(jìn)入到TimeWaiting(計(jì)時(shí)等待)有兩種方式1.使用sleep(long m)方法,在毫秒值結(jié)束之后,線程睡醒進(jìn)入到Runnable/Blocked狀態(tài)2.使用wait(long m)方法,wait方法如果在毫秒值結(jié)束之后,還沒有被notify喚醒,就會(huì)自動(dòng)醒來,線程睡醒進(jìn)入到Runnable/Blocked狀態(tài)

喚醒的方法:void notify() 喚醒在此對(duì)象監(jiān)視器上等待的單個(gè)線程。void notifyAll() 喚醒在此對(duì)象監(jiān)視器上等待的所有線程。

public static void main(String[] args) { //創(chuàng)建鎖對(duì)象,保證唯一 final Object obj = new Object(); // 創(chuàng)建一個(gè)顧客線程(消費(fèi)者) new Thread(){ @Override public void run() { //一直等著買包子 while(true){//保證等待和喚醒的線程只能有一個(gè)執(zhí)行,需要使用同步技術(shù)synchronized (obj){ System.out.println('顧客1告知老板要的包子的種類和數(shù)量'); //調(diào)用wait方法,放棄cpu的執(zhí)行,進(jìn)入到WAITING狀態(tài)(無限等待) try { obj.wait(); } catch (InterruptedException e) { e.printStackTrace(); } //喚醒之后執(zhí)行的代碼 System.out.println('包子已經(jīng)做好了,顧客1開吃!'); System.out.println('---------------------------------------');} } } }.start(); // 創(chuàng)建一個(gè)顧客線程(消費(fèi)者) new Thread(){ @Override public void run() { //一直等著買包子 while(true){//保證等待和喚醒的線程只能有一個(gè)執(zhí)行,需要使用同步技術(shù)synchronized (obj){ System.out.println('顧客2告知老板要的包子的種類和數(shù)量'); //調(diào)用wait方法,放棄cpu的執(zhí)行,進(jìn)入到WAITING狀態(tài)(無限等待) try { obj.wait(); } catch (InterruptedException e) { e.printStackTrace(); } //喚醒之后執(zhí)行的代碼 System.out.println('包子已經(jīng)做好了,顧客2開吃!'); System.out.println('---------------------------------------');} } } }.start(); //創(chuàng)建一個(gè)老板線程(生產(chǎn)者) new Thread(){ @Override public void run() { //一直做包子 while (true){//花了5秒做包子try { Thread.sleep(5000);//花5秒鐘做包子} catch (InterruptedException e) { e.printStackTrace();}//保證等待和喚醒的線程只能有一個(gè)執(zhí)行,需要使用同步技術(shù)synchronized (obj){ System.out.println('老板5秒鐘之后做好包子,告知顧客,可以吃包子了'); //做好包子之后,調(diào)用notify方法,喚醒顧客吃包子 //obj.notify();//如果有多個(gè)等待線程,隨機(jī)喚醒一個(gè) obj.notifyAll();//喚醒所有等待的線程} } } }.start();}

Java 線程狀態(tài)和等待喚醒機(jī)制和線程池的實(shí)現(xiàn)

2.等待喚醒機(jī)制

就是在一個(gè)線程進(jìn)行了規(guī)定操作后,就進(jìn)入等待狀態(tài)(wait()), 等待其他線程執(zhí)行完他們的指定代碼過后 再將其喚醒notify();在有多個(gè)線程進(jìn)行等待時(shí), 如果需要,可以使用 notifyAll()來喚醒所有的等待線程。wait/notify 就是線程間的一種協(xié)作機(jī)制。

等待喚醒中的方法 :

wait:線程不再活動(dòng),不再參與調(diào)度,進(jìn)入 wait set 中,因此不會(huì)浪費(fèi) CPU 資源,也不會(huì)去競(jìng)爭(zhēng)鎖了,這時(shí)的線程狀態(tài)即是 WAITING。它還要等著別的線程執(zhí)行一個(gè)特別的動(dòng)作,也即是“通知(notify)”在這個(gè)對(duì)象上等待的線程從wait set 中釋放出來,重新進(jìn)入到調(diào)度隊(duì)列(ready queue)中 notify:則選取所通知對(duì)象的 wait set 中的一個(gè)線程釋放;例如,餐館有空位置后,等候就餐最久的顧客最先入座。 notifyAll:則釋放所通知對(duì)象的 wait set 上的全部線程。

3.線程池

線程池其實(shí)就是一個(gè)容納多個(gè)線程的容器,其中的線程可以反復(fù)使用,省去了頻繁創(chuàng)建線程對(duì)象的操作,無需反復(fù)創(chuàng)建線程而消耗過多資源。

Java 線程狀態(tài)和等待喚醒機(jī)制和線程池的實(shí)現(xiàn)

Java里面線程池的頂級(jí)接口是java.util.concurrent.Executor,但是嚴(yán)格意義上講Executor并不是一個(gè)線程池,而只是一個(gè)執(zhí)行線程的工具。真正的線程池接口是java.util.concurrent.ExecutorService。 要配置一個(gè)線程池是比較復(fù)雜的,尤其是對(duì)于線程池的原理不是很清楚的情況下,很有可能配置的線程池不是較優(yōu)的,因此在java.util.concurrent.Executors線程工廠類里面提供了一些靜態(tài)工廠,生成一些常用的線程池。官方建議使用Executors工程類來創(chuàng)建線程池對(duì)象。

使用:

線程池:JDK1.5之后提供的 java.util.concurrent.Executors:線程池的工廠類,用來生成線程池 Executors類中的靜態(tài)方法:static ExecutorService newFixedThreadPool(int nThreads) 創(chuàng)建一個(gè)可重用固定線程數(shù)的線程池參數(shù): int nThreads:創(chuàng)建線程池中包含的線程數(shù)量返回值: ExecutorService接口,返回的是ExecutorService接口的實(shí)現(xiàn)類對(duì)象,我們可以使用ExecutorService接口接收(面向接口編程) java.util.concurrent.ExecutorService:線程池接口用來從線程池中獲取線程,調(diào)用start方法,執(zhí)行線程任務(wù) submit(Runnable task) 提交一個(gè) Runnable 任務(wù)用于執(zhí)行關(guān)閉/銷毀線程池的方法 void shutdown()

線程池的使用步驟:1.使用線程池的工廠類Executors里邊提供的靜態(tài)方法newFixedThreadPool生產(chǎn)一個(gè)指定線程數(shù)量的線程池2.創(chuàng)建一個(gè)類,實(shí)現(xiàn)Runnable接口,重寫run方法,設(shè)置線程任務(wù)3.調(diào)用ExecutorService中的方法submit,傳遞線程任務(wù)(實(shí)現(xiàn)類),開啟線程,執(zhí)行run方法4.調(diào)用ExecutorService中的方法shutdown銷毀線程池(不建議執(zhí)行)

例子:

public class RunnableImpl implements Runnable{ @Override public void run() { System.out.println(Thread.currentThread().getName()+'創(chuàng)建了一個(gè)新的線程執(zhí)行'); }} public static void main(String[] args) { //1.使用線程池的工廠類Executors里邊提供的靜態(tài)方法newFixedThreadPool生產(chǎn)一個(gè)指定線程數(shù)量的線程池 ExecutorService es = Executors.newFixedThreadPool(2); //3.調(diào)用ExecutorService中的方法submit,傳遞線程任務(wù)(實(shí)現(xiàn)類),開啟線程,執(zhí)行run方法 es.submit(new RunnableImpl());//pool-1-thread-1創(chuàng)建了一個(gè)新的線程執(zhí)行 //線程池會(huì)一直開啟,使用完了線程,會(huì)自動(dòng)把線程歸還給線程池,線程可以繼續(xù)使用 es.submit(new RunnableImpl());//pool-1-thread-1創(chuàng)建了一個(gè)新的線程執(zhí)行 es.submit(new RunnableImpl());//pool-1-thread-2創(chuàng)建了一個(gè)新的線程執(zhí)行 //4.調(diào)用ExecutorService中的方法shutdown銷毀線程池(不建議執(zhí)行) es.shutdown(); es.submit(new RunnableImpl());//拋異常,線程池都沒有了,就不能獲取線程了}

Java 線程狀態(tài)和等待喚醒機(jī)制和線程池的實(shí)現(xiàn)

到此這篇關(guān)于Java 線程狀態(tài)和等待喚醒機(jī)制和線程池的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Java 線程狀態(tài)和等待喚醒機(jī)制 內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 欧美成人亚洲高清在线观看 | 久久99精品一级毛片 | 免费国产不卡午夜福在线 | 黄色美女视频免费看 | 国产精品久久久久久久久久久久 | 韩日黄色 | 成人三级在线视频 | 九九精品国产兔费观看久久 | 精品国产综合成人亚洲区 | 亚洲免费视频在线观看 | 一区二区三区免费视频 www | 亚洲高清在线视频 | 亚洲视频在线网 | 黄色三级视频网站 | 日韩精品一级a毛片 | 久草在线免费福利视频 | 成人亚洲精品777777 | 成人性版蝴蝶影院污 | 亚洲精品国产拍拍拍拍拍 | 国产精选在线播放 | 国产人做人爱视频精品 | 日本美女作爱 | 在线永久免费观看黄网站 | 国内外成人免费视频 | 美女张开腿给男人桶 | 亚洲国产天堂久久精品网 | 国产亚洲一区二区精品 | 性高湖久久久久久久久 | 二级毛片在线播放 | 91久久网| 久久一区二区精品 | 一级免费视频 | 日韩一及片| 国产精品国产高清国产专区 | 亲子乱子伦xxxx | 美女视频大全网站免费 | 欧美一级特黄aaa大片 | 国内外成人免费在线视频 | 女人张开腿让男人桶免费网站 | 欧美一级aⅴ毛片 | 天天干夜夜怕 |