成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

聊聊Java中是什么方法導(dǎo)致的線程阻塞

瀏覽:170日期:2022-08-16 15:17:18
一、為什么引入線程阻塞機制?

為了解決對共享存儲區(qū)的訪問沖突,Java 引入了同步機制,現(xiàn)在讓我們來考察多個線程對共享資源的訪問,顯然同步機制已經(jīng)不夠了,因為在任意時刻所要求的資源不一定已經(jīng)準(zhǔn)備好了被訪問,反過來,同一時刻準(zhǔn)備好了的資源也可能不止一個。為了解決這種情況下的訪問控制問題,Java 引入了對阻塞機制的支持

阻塞指的是暫停一個線程的執(zhí)行以等待某個條件發(fā)生(如某資源就緒),學(xué)過操作系統(tǒng)的同學(xué)對它一定已經(jīng)很熟悉了。Java 提供了大量方法來支持阻塞,下面讓我們逐一分析。

二、Java中實現(xiàn)線程阻塞的方法:

(1)線程睡眠:Thread.sleep (long millis)方法,使線程轉(zhuǎn)到阻塞狀態(tài)。millis參數(shù)設(shè)定睡眠的時間,以毫秒為單位。當(dāng)睡眠結(jié)束后,就轉(zhuǎn)為就緒(Runnable)狀態(tài)。sleep()平臺移植性好。

(2)線程等待:Object類中的wait()方法,導(dǎo)致當(dāng)前的線程等待,直到其他線程調(diào)用此對象的 notify() 喚醒方法。這個兩個喚醒方法也是Object類中的方法,行為等價于調(diào)用 wait() 一樣。wait() 和 notify() 方法:兩個方法配套使用,wait() 使得線程進(jìn)入阻塞狀態(tài),它有兩種形式,一種允許 指定以毫秒為單位的一段時間作為參數(shù),另一種沒有參數(shù),前者當(dāng)對應(yīng)的 notify() 被調(diào)用或者超出指定時間時線程重新進(jìn)入可執(zhí)行狀態(tài),后者則必須對應(yīng)的 notify() 被調(diào)用.

(3)線程禮讓,Thread.yield() 方法,暫停當(dāng)前正在執(zhí)行的線程對象,把執(zhí)行機會讓給相同或者更高優(yōu)先級的線程。yield() 使得線程放棄當(dāng)前分得的 CPU 時間,但是不使線程阻塞,即線程仍處于可執(zhí)行狀態(tài),隨時可能再次分得 CPU 時間。調(diào)用 yield() 的效果等價于調(diào)度程序認(rèn)為該線程已執(zhí)行了足夠的時間從而轉(zhuǎn)到另一個線程.

(4)線程自閉,join()方法,等待其他線程終止。在當(dāng)前線程中調(diào)用另一個線程的join()方法,則當(dāng)前線程轉(zhuǎn)入阻塞狀態(tài),直到另一個進(jìn)程運行結(jié)束,當(dāng)前線程再由阻塞轉(zhuǎn)為就緒狀態(tài)。

(5)suspend() 和 resume() 方法:兩個方法配套使用,suspend()使得線程進(jìn)入阻塞狀態(tài),并且不會自動恢復(fù),必須其對應(yīng)的resume() 被調(diào)用,才能使得線程重新進(jìn)入可執(zhí)行狀態(tài)。典型地,suspend() 和 resume() 被用在等待另一個線程產(chǎn)生的結(jié)果的情形:測試發(fā)現(xiàn)結(jié)果還沒有產(chǎn)生后,讓線程阻塞,另一個線程產(chǎn)生了結(jié)果后,調(diào)用 resume() 使其恢復(fù)。Thread中suspend()和resume()兩個方法在JDK1.5中已經(jīng)廢除,不再介紹。因為有死鎖傾向。

這里,筆者放入一張線程生命周期的經(jīng)典圖片,來幫助讀者理解,里面展示了一個線程從創(chuàng)建->運行->阻塞->運行->死亡的全過程:

聊聊Java中是什么方法導(dǎo)致的線程阻塞

三、常用線程名詞解釋

主線程:JVM調(diào)用程序main()所產(chǎn)生的線程。

當(dāng)前線程:這個是容易混淆的概念。一般指通過Thread.currentThread()來獲取的進(jìn)程。

后臺線程:指為其他線程提供服務(wù)的線程,也稱為守護(hù)線程。JVM的垃圾回收線程就是一個后臺線程。用戶線程和守護(hù)線程的區(qū)別在于,是否等待主線程依賴于主線程結(jié)束而結(jié)束

前臺線程:是指接受后臺線程服務(wù)的線程,其實前臺后臺線程是聯(lián)系在一起,就像傀儡和幕后操縱者一樣的關(guān)系??苁乔芭_線程、幕后操縱者是后臺線程。由前臺線程創(chuàng)建的線程默認(rèn)也是前臺線程。可以通過isDaemon()和setDaemon()方法來判斷和設(shè)置一個線程是否為后臺線程。

可見進(jìn)程:可見進(jìn)程是指一些不在前臺,但用戶依然可見的進(jìn)程,舉例來說:各種widget、輸入法等,都屬于visibe。這部分進(jìn)程雖然不在前臺,但與我們的使用也是密切相關(guān),我們并不希望它被系統(tǒng)終止。

“前臺可見進(jìn)程服務(wù)于后臺空進(jìn)程”——這是記錄線程重要性的口訣,

重要性一次遞減即,前臺進(jìn)程>可見進(jìn)程>服務(wù)進(jìn)程>后臺進(jìn)程>空進(jìn)程。

線程類的一些常用方法:

sleep(): 強迫一個線程睡眠N毫秒。

isAlive(): 判斷一個線程是否存活。

join(): 等待線程終止。

activeCount(): 程序中活躍的線程數(shù)。

enumerate(): 枚舉程序中的線程。

currentThread(): 得到當(dāng)前線程。

isDaemon(): 一個線程是否為守護(hù)線程。

setDaemon(): 設(shè)置一個線程為守護(hù)線程。(用戶線程和守護(hù)線程的區(qū)別在于,是否等待主線程依賴于主線程結(jié)束而結(jié)束)

setName(): 為線程設(shè)置一個名稱。

wait(): 強迫一個線程等待。

notify(): 通知一個線程繼續(xù)運行。

setPriority(): 設(shè)置一個線程的優(yōu)先級。

補充:java處理線程阻塞的小技巧

在java中我們使用多線程去處理一些業(yè)務(wù),如果業(yè)務(wù)比較復(fù)雜且當(dāng)并發(fā)量有挺大的時候,很有可能出現(xiàn)線程阻塞的問題。

案例:

有一個觸發(fā)接口,根據(jù)觸發(fā)的信息內(nèi)部開啟多個線程去執(zhí)行業(yè)務(wù),每個線程都會去執(zhí)行兩種業(yè)務(wù):私有業(yè)務(wù)(比如調(diào)用不同的接口)、公共業(yè)務(wù)(比如執(zhí)行存儲、mq發(fā)送等等),當(dāng)私有業(yè)務(wù)處理時間很快而公共業(yè)務(wù)處理時間比較長,這樣的情景下就可以把私有業(yè)務(wù)和公共業(yè)務(wù)分到不同線程執(zhí)行。

例如:

當(dāng)觸發(fā)了這個接口,根據(jù)接口觸發(fā)的信息,需要開啟10個線程,那么就可以創(chuàng)建10個線程去執(zhí)行它的私有業(yè)務(wù),然后再額外創(chuàng)建一個線程去拿到前面那10個線程的執(zhí)行返回結(jié)果并進(jìn)行公共業(yè)務(wù)的處理。

這樣有個好處,就是能讓線程池很快的回收線程,能有效防止線程的阻塞

量化:

單個私有業(yè)務(wù)1秒鐘能執(zhí)行完成,單個公共業(yè)務(wù)需要5秒鐘才能執(zhí)行完成,如果接口被觸發(fā),發(fā)現(xiàn)需要創(chuàng)建100個線程執(zhí)行,那么線程池回收這些線程池至少需要等待6秒,如果按照前面說的分成兩個線程,那么就需要創(chuàng)建101個線程,而1秒后就能回收掉執(zhí)行完成的100個線程

但是這里需要做權(quán)衡,如果接口被觸發(fā)的時候發(fā)現(xiàn)需要開啟的線程比較多且公共業(yè)務(wù)很耗時,這種情況下執(zhí)行公共業(yè)務(wù)只有單個線程同步執(zhí)行,那么這個線程就會執(zhí)行比較長的時間,所以執(zhí)行公共業(yè)務(wù)的時候也可根據(jù)實際情況開啟多個線程。

下面寫了個小demo:1.私有業(yè)務(wù)的類:

@Componentpublic class Calculation { public Result cal(String req, int a, int b) { System.out.println('請求id:' + req + ' 結(jié)果:' + (a + b)); return new Result(req, a + b); }}2.公共業(yè)務(wù)的類:

@Componentpublic class SomethingElse { public void doElse(Result result) { try { System.out.println(Thread.currentThread().getName() + ' : 開始做其他事情,請求號:' + result.getReq() + ' ,請求結(jié)果:' + result.getSum()); Thread.sleep(2000); System.out.println(Thread.currentThread().getName() + ' : 完成做其他事情,請求號:' + result.getReq() + ' ,請求結(jié)果:' + result.getSum()); } catch (InterruptedException e) { } }}3.私有業(yè)務(wù)的線程類:

public class CallTask implements Callable<Result> { private String req; private int a; private int b; @Override public Result call() throws Exception { Calculation calculation = Main.applicationContext.getBean(Calculation.class); return calculation.cal(req, a, b); } public CallTask(String req, int a, int b) { this.req = req; this.a = a; this.b = b; } // getter and setter 等等}4.公共業(yè)務(wù)的線程類:

public class ElseTask implements Runnable { private CompletionService<Result> cs; private int threadCount; public ElseTask(CompletionService<Result> cs, int threadCount) { this.cs = cs; this.threadCount = threadCount; } @Override public void run() { SomethingElse somethingElse = Main.applicationContext.getBean(SomethingElse.class); doElse(somethingElse); } private void doElse(SomethingElse somethingElse) { try { for (int i = 0; i < threadCount; i++) {Future<Result> take = cs.take();Result result = take.get();somethingElse.doElse(result); } } catch (Exception e) { } } // getter and setter 等等}6.測試主方法:

@Servicepublic class Main implements ApplicationContextAware { public static ApplicationContext applicationContext = null; public static void main(String[] args) throws InterruptedException { AbstractApplicationContext appContext = new ClassPathXmlApplicationContext('application01.xml'); ExecutorService executorService = Executors.newFixedThreadPool(100); CompletionService<Result> cs = new ExecutorCompletionService(executorService); //這里啟動執(zhí)行計算的線程 cs.submit(new CallTask('req001', 0, 1)); cs.submit(new CallTask('req002', 0, 2)); cs.submit(new CallTask('req003', 0, 3)); cs.submit(new CallTask('req004', 0, 4)); cs.submit(new CallTask('req005', 0, 5)); //專門的監(jiān)控線程,并執(zhí)行其他耗時的線程 executorService.execute(new ElseTask(cs, 5)); executorService.shutdown(); appContext.registerShutdownHook(); } @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext = applicationContext; }}

執(zhí)行結(jié)果如下:

聊聊Java中是什么方法導(dǎo)致的線程阻塞

核心思想: 將多線程的公有的業(yè)務(wù)抽出來(前提是公有業(yè)務(wù)比較耗時,不然就沒必要了)在其他線程里面執(zhí)行。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。如有錯誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Java
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
成人做爰69片免费看网站| 狠狠入ady亚洲精品经典电影| 一区二区不卡在线视频 午夜欧美不卡在| 日韩免费看的电影| 国产精品成人网| 日韩免费观看高清完整版在线观看| 91麻豆精品91久久久久同性| 欧美精品一级二级| 欧美肥妇毛茸茸| 日韩一区二区精品在线观看| 日韩一区二区免费高清| 2021中文字幕一区亚洲| 国产午夜久久久久| 亚洲男人的天堂av| 亚洲久久一区| 蜜臀久久久99精品久久久久久| 亚洲一区在线看| 亚洲动漫第一页| 日韩电影免费一区| 国产麻豆成人精品| 午夜精彩国产免费不卡不顿大片| 欧美另类专区| 欧美亚洲免费| 69精品人人人人| 久久这里只有精品视频网| 国产精品素人一区二区| 一区二区三区欧美日韩| 青青草国产成人av片免费| 国产激情一区二区三区| 欧美激情视频一区二区三区在线播放| 亚洲美女视频在线免费观看 | 亚洲欧美日本日韩| 欧美午夜片在线看| 精品成人佐山爱一区二区| 国产成人亚洲综合a∨婷婷图片| 亚洲最大成人网4388xx| 久久精品国产在热久久| 成人h精品动漫一区二区三区| 欧美精品一线| 午夜一级久久| 精品久久久久久久人人人人传媒| 日韩美女啊v在线免费观看| 蜜臀a∨国产成人精品| proumb性欧美在线观看| 国产精品一区亚洲| 日韩精品在线网站| 亚洲高清免费观看| 91视频在线看| 日本韩国精品在线| 国产精品嫩草久久久久| 另类的小说在线视频另类成人小视频在线| 91在线观看免费视频| 一本色道久久综合狠狠躁的推荐| 久久欧美中文字幕| 捆绑调教一区二区三区| 国内综合精品午夜久久资源| 欧美精品 日韩| 一区二区免费视频| 91在线高清观看| 在线观看网站黄不卡| 国产精品久久久99| 国产美女精品在线| 久久亚洲一区二区| 亚洲猫色日本管| 成人在线一区二区三区| 色欧美日韩亚洲| 亚洲欧美另类图片小说| 成人av在线网| 欧美视频在线不卡| 亚洲午夜电影在线观看| 亚洲欧美日韩精品久久久| 国产欧美va欧美不卡在线| 韩国三级中文字幕hd久久精品| 夜夜嗨av一区二区三区网站四季av| 欧美不卡在线视频| 国产一区中文字幕| 在线观看三级视频欧美| 亚洲午夜久久久久中文字幕久| 欧美理论在线| 久久人人爽爽爽人久久久| 国产成人av影院| 在线观看亚洲精品| 日韩中文字幕1| 国产精品久久久久久模特| 欧美经典一区二区| zzijzzij亚洲日本少妇熟睡| 欧美老肥妇做.爰bbww| 青青草国产精品亚洲专区无| 国产美女在线精品免费观看| 亚洲精选一二三| 亚洲国产黄色| 成人欧美一区二区三区小说 | 欧美区亚洲区| 亚洲国产精品av| 午夜国产精品视频| 欧美韩国一区二区| 亚洲欧美亚洲| 国产精品色在线| 激情欧美国产欧美| 亚洲激情自拍偷拍| 99在线精品免费视频九九视| 亚洲丝袜美腿综合| 国产精品毛片va一区二区三区| 亚洲天堂2016| 国产精品一区二区在线观看| 午夜精品视频在线观看| 老司机精品视频网站| 青青草国产成人av片免费| 在线观看av一区二区| 极品少妇xxxx精品少妇偷拍| 在线播放亚洲一区| 国产99久久久国产精品| www国产精品av| 午夜日韩电影| 一片黄亚洲嫩模| 91久久精品一区二区| 国产一区二区免费视频| 日韩欧美不卡在线观看视频| 欧美在线免费一级片| 亚洲卡通欧美制服中文| 久久国产直播| 国内成人自拍视频| 久久精品在这里| 在线精品福利| 亚洲人成久久| 蜜桃一区二区三区四区| 欧美一区二区在线视频| 色综合网色综合| 一级女性全黄久久生活片免费| 美玉足脚交一区二区三区图片| 久久国产生活片100| 久久影院视频免费| 在线亚洲一区| 国产综合久久久久久久久久久久| 精品美女被调教视频大全网站| 国产精品第十页| 五月婷婷久久丁香| 精品处破学生在线二十三| 国产婷婷精品| 国产精品77777竹菊影视小说| 国产精品无码永久免费888| 美女国产一区| 91在线视频18| 丝袜亚洲另类欧美| 久久免费视频色| 欧美一进一出视频| 99天天综合性| 午夜激情综合网| 久久久久久久久久久黄色| 久久国产高清| 99r国产精品| 日韩av不卡在线观看| 国产午夜精品理论片a级大结局| 老鸭窝91久久精品色噜噜导演| 国产91丝袜在线18| 亚洲线精品一区二区三区| 日韩一区二区三区四区| 午夜在线精品| 欧美jjzz| 国模娜娜一区二区三区| 中文字幕欧美一| 欧美电视剧免费全集观看| 久久久久.com| 国产精品hd| 国产91精品一区二区麻豆亚洲| 成人黄色一级视频| 一二三四区精品视频| 精品粉嫩超白一线天av| 91福利资源站| 国产欧美日韩一区二区三区在线| 成人免费视频网站在线观看| 午夜精品一区在线观看| 中文一区在线播放| 欧美成人一区二区三区在线观看 | 欧美精品日韩精品| 男女精品视频| 国产主播一区| 97精品视频在线观看自产线路二| 免费观看成人鲁鲁鲁鲁鲁视频| 国产精品午夜在线| 精品99一区二区| 欧美三级资源在线| 久久国产日本精品| 亚洲黄网站黄| 黄色亚洲免费| 午夜精品视频在线观看一区二区| 国产精品系列在线播放| 蜜臀av一级做a爰片久久| 亚洲国产wwwccc36天堂| 亚洲欧美激情一区二区| 国产精品久久久久影院亚瑟| 精品成a人在线观看| 日韩一区二区在线免费观看| 欧美裸体一区二区三区| 在线观看日韩电影| 欧美优质美女网站| 久久久久综合一区二区三区| 亚洲一级在线| 久久只有精品| 日本电影亚洲天堂一区|