日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Java簡(jiǎn)單實(shí)現(xiàn)線程池

瀏覽:134日期:2022-08-13 15:14:24

本文實(shí)例為大家分享了Java簡(jiǎn)單實(shí)現(xiàn)線程池的具體代碼,供大家參考,具體內(nèi)容如下

一、線程池

線程池是一種緩沖提高效率的技術(shù)。相當(dāng)于一個(gè)池子,里面存放大量已經(jīng)創(chuàng)建好的線程,當(dāng)有一個(gè)任務(wù)需要處理時(shí), 可以直接從池子里面取一個(gè)線程去執(zhí)行它。 包括內(nèi)存池,很多緩沖的技術(shù)都是采用這種技術(shù)。 其實(shí)理解起來(lái)很簡(jiǎn)答!

為什么需要線程池,這種池的技術(shù)?

1.1 減少開辟資源和銷毀資源帶來(lái)的損耗。

開辟線程,申請(qǐng)內(nèi)存(具體的可以看C語(yǔ)言中malloc底層實(shí)現(xiàn)原理),銷毀線程、釋放內(nèi)存資源等一些操作都是有時(shí)間消耗的。因此一開始開辟大量的資源進(jìn)行管理,需要使用時(shí)從池中取一個(gè)去使用, 使用完畢后再放回池中管理, 這樣可以避免資源開辟和銷毀帶來(lái)的時(shí)間損耗。

1.2 提高響應(yīng)。

用戶來(lái)了一個(gè)請(qǐng)求, 能夠立刻從開辟好的線程池中取一個(gè)線程去處理執(zhí)行。 提高響應(yīng)效率,提高用戶體驗(yàn)。

1.3 有效管理資源

管理資源統(tǒng)一開辟和銷毀, 監(jiān)控線程狀態(tài)和調(diào)優(yōu)

二、線程池分析

對(duì)于線程池的實(shí)現(xiàn)我們劃分為2個(gè)部分

1、線程安全的任務(wù)隊(duì)列(采用隊(duì)列,不過(guò)是線程安全的而已),保證工作線程在去任務(wù)時(shí)不會(huì)發(fā)生沖突(重復(fù)取同一個(gè)任務(wù)處理,二次執(zhí)行或者多次的問(wèn)題)。2、對(duì)工作線程的監(jiān)管(采用是List管理工作線程),方便線程的銷毀和管理。

線程池處理邏輯:

1、每當(dāng)添加一個(gè)任務(wù),就會(huì)從線程池中取一個(gè)工作線程去處理執(zhí)行它。2、沒(méi)有任務(wù)處理時(shí), 工作線程應(yīng)該處于阻塞狀態(tài)等待任務(wù)到來(lái), 不會(huì)競(jìng)爭(zhēng)占用CPU資源3、線程池相當(dāng)于生產(chǎn)-消費(fèi)模型, 只不過(guò)生產(chǎn)線程的中生產(chǎn)任務(wù)不同罷了。

3、主線程相當(dāng)于監(jiān)管線程,最終負(fù)責(zé)工作線程的銷毀。

三、線程池實(shí)現(xiàn)

1、 工作線程Worker

1.1、工作線程負(fù)責(zé)從阻塞任務(wù)隊(duì)列中取出任務(wù)執(zhí)行。由于存在很多個(gè)線程對(duì)同一個(gè)隊(duì)列操作,因此這個(gè)任務(wù)隊(duì)列一定得是線程安全的(采用BlockingQueue接口, 這是GUC提供的,線程安全)1.2、工作線程的創(chuàng)建方式屬于線程創(chuàng)建的方式之一。1.3、每個(gè)工作線程都維護(hù)一個(gè)阻塞任務(wù)隊(duì)列。1.4、線程的執(zhí)行方法run()中,以線程的中斷狀態(tài)為循環(huán)判斷條件(方便線程銷毀, 只要將工作線程的中斷狀態(tài)置為true即可釋放工作線程)其次就是BlockingQueue接口提供的take()方法。

Java簡(jiǎn)單實(shí)現(xiàn)線程池

該方法在隊(duì)列沒(méi)有元素時(shí)處于阻塞狀態(tài),直接取到元素,這樣就解決了沒(méi)有任務(wù)工作線程處于阻塞狀態(tài),不會(huì)搶占CPU

//實(shí)現(xiàn)工作線程 - 工作線程中維護(hù)了公有的任務(wù)隊(duì)列(阻塞), 工作線程的執(zhí)行邏輯。 循環(huán)取隊(duì)列中的任務(wù)去執(zhí)行處理。class Worker extends Thread { //阻塞任務(wù)隊(duì)列 - 可以保證多個(gè)線程對(duì)隊(duì)列操作, 線程安全 private BlockingQueue<Runnable> queue = null; //每個(gè)工作線程都會(huì)有一個(gè)阻塞隊(duì)列,這個(gè)隊(duì)列中保存了所有的任務(wù) public Worker(BlockingQueue<Runnable> queue, int id) {this.queue = queue; // Thread.currentThread().setName('郝夢(mèng)武' + id + '號(hào)工作線程'); }//工作線程執(zhí)行內(nèi)容 @Override public void run() {//每個(gè)線程通過(guò)isInterrupted()判斷線程異常狀態(tài)。try { while (!Thread.currentThread().isInterrupted()) {//如果線程正常, 返回false, 出現(xiàn)異常, 返回true, 該狀態(tài)默認(rèn)為falseRunnable command = queue.take(); //如果隊(duì)列為空, take會(huì)讓線程阻塞System.out.println(Thread.currentThread().getName() + '正在處理任務(wù)' + command.hashCode());command.run(); }}catch(InterruptedException e) { System.out.println(Thread.currentThread().getName() + '被中止了');// e.printStackTrace(); //不需要拋出異常} }}

2、線程池對(duì)象MyThreadPool

1、創(chuàng)建工作線程并管理,添加任務(wù)。2、銷毀所有工作線程

//線程池 - 維護(hù)很多個(gè)線程, 當(dāng)來(lái)一個(gè)任務(wù)時(shí), 從線程池中獲取一個(gè)線程去處理執(zhí)行。//好處: 防止線程頻繁開辟和銷毀帶來(lái)的性能損耗class MyThreadPool { //創(chuàng)建任務(wù)線程安全的隊(duì)列, 保證多個(gè)線程對(duì)這個(gè)隊(duì)列操作時(shí)是線程安全的 private BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>(); //線程管理列表 - 這個(gè)列表保存了所有線程對(duì)象的引用, 方便后續(xù)的管理 private List<Worker> Wokers = new ArrayList<>(); private final static int maxWorkerCount = 10; //線程池最大允許的個(gè)數(shù) //execute方法 public void execute(Runnable command) throws InterruptedException {if(Wokers.size() < maxWorkerCount) { //創(chuàng)建一個(gè)新的工作線程 Worker worker = new Worker(queue, Wokers.size()); //創(chuàng)建工作線程 worker.start(); //創(chuàng)建的工程線程啟動(dòng) Wokers.add(worker); //添加到管理列表中}queue.put(command); //添加任務(wù)到線程安全的隊(duì)列中 } //銷毀所有線程 - 將每個(gè)線程中狀態(tài)置為中斷狀態(tài)方法, 并且 public void shutDown() throws InterruptedException {for(Worker worker : Wokers) { worker.interrupt(); //將線程的狀態(tài)置為中斷, 調(diào)用isInterruptd()返回值為true}//并且讓主線程join阻塞等待所有工作線程for(Worker worker : Wokers) { worker.join(); //join方法可以讓調(diào)用的線程處于阻塞狀態(tài), 知道等待的線程結(jié)束完畢之后就會(huì)恢復(fù)}//執(zhí)行到這塊, 代表所有的線程銷毀完畢System.out.println('所有工作線程銷毀完畢!'); }}

3、測(cè)試代碼

class MyRunnable implements Runnable { private int num; MyRunnable(int num) {this.num = num; } @Override public void run() {System.out.println('正在執(zhí)行任務(wù): ' + num); }}public static void main(String[] args) throws InterruptedException { MyThreadPool myThreadPool = new MyThreadPool(); for(int i = 0; i < 1000; i++) { myThreadPool.execute(new MyRunnable(i + 1)); } Thread.sleep(2000); //主線程休眠2s myThreadPool.shutDown(); //銷毀所有工作線程 System.out.println('線程池已經(jīng)被銷毀了'); }

4、測(cè)試結(jié)果

Java簡(jiǎn)單實(shí)現(xiàn)線程池

Java簡(jiǎn)單實(shí)現(xiàn)線程池

總結(jié):

以上的代碼只是簡(jiǎn)單模擬實(shí)現(xiàn)了線程池。不僅僅是線程池,內(nèi)容池,還有很多池的應(yīng)用場(chǎng)景。池的技術(shù)雖然能夠起到快速響應(yīng)的特點(diǎn),但是還是存在問(wèn)題。第一點(diǎn): 池需要在一開始創(chuàng)建很多資源, 這和我們機(jī)器內(nèi)存大小有關(guān)系。第二點(diǎn): 池中的線程過(guò)多,但是任務(wù)過(guò)少,導(dǎo)致很多線程浪費(fèi)掉, 因此池中開辟多大的資源需要根據(jù)實(shí)際情況而言。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精精国产xxxx视频在线野外| 男人的天堂亚洲一区| 1000部精品久久久久久久久| 日本va欧美va瓶| 久久国产中文字幕| 欧美日韩xxxx| 合欧美一区二区三区| 麻豆精品视频在线观看视频| 9色精品在线| 高清久久一区| 久久亚洲精品伦理| 理论片午夜视频在线观看| 日本va欧美va瓶| 免费av一区二区三区四区| 欧美激情综合| 蜜桃视频在线观看一区二区| 欧美成人a交片免费看| 欧美日韩91| 日韩精品一区第一页| 天堂中文在线播放| 国产日韩亚洲欧美精品| 视频一区欧美精品| 国产亚洲一区二区手机在线观看 | 亚洲在线成人| 黄色在线网站噜噜噜| 国产欧美亚洲一区| 综合在线一区| 亚洲欧美网站| 亚洲国产影院| 久久久久久一区二区| 91精品日本| 亚洲一区二区三区在线免费| 欧美91视频| 天堂8中文在线最新版在线| 国产精品久久久久久久久久久久久久久| 亚洲神马久久| 美女网站一区| 午夜精品成人av| 里番精品3d一二三区| 日韩二区在线观看| 亚洲深深色噜噜狠狠爱网站 | 国产一区二区三区四区五区 | 久久蜜桃资源一区二区老牛| 欧美国产极品| 国产欧美日韩影院| 日韩中文字幕在线一区| 美女网站久久| 亚洲欧美日韩精品一区二区| 激情五月综合| 久久国产精品成人免费观看的软件| 国产精品白丝av嫩草影院| 日韩精品一页| 日韩综合一区二区三区| 亚洲精品护士| 亚洲欧美在线专区| 三级在线观看一区二区| 99视频精品| 亚洲少妇在线| 久热精品在线| 蜜臀精品久久久久久蜜臀| 亚洲欧美日韩专区| 欧美中文日韩| 日韩影院精彩在线| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产精品人人爽人人做我的可爱| 久久久久久美女精品| 久久精品高清| 黄色av日韩| 免费在线观看成人| 一区二区三区网站| 日韩午夜视频在线| 国产日韩欧美三级| 久久影院一区二区三区| 精品国产午夜| 日产精品一区| 欧洲激情综合| 国产精品嫩草99av在线| 中文字幕一区二区三区日韩精品 | 欧美日韩夜夜| 国产精品蜜月aⅴ在线| 国产精品久久久亚洲一区| 精品一区二区三区在线观看视频| 精品一区二区三区中文字幕视频 | 蜜臀av性久久久久蜜臀aⅴ流畅| 视频一区免费在线观看| 五月亚洲婷婷 | 日韩在线观看| 91精品在线观看国产| 亚洲经典在线| 日本不卡一区二区| 麻豆精品在线视频| 97精品国产福利一区二区三区| 亚洲黄色中文字幕| 精品一区毛片| 亚洲毛片在线| 另类欧美日韩国产在线| 91精品xxx在线观看| 夜夜嗨一区二区| 日本视频在线一区| 成人精品高清在线视频| 欧美福利在线| 婷婷综合一区| 国产精品99一区二区三区| 五月天激情综合网| 日韩激情av在线| www在线观看黄色| 欧美日韩国产亚洲一区| 日韩一区二区三区精品| 国产成人精品亚洲线观看| 欧美日韩激情| 欧美视频精品全部免费观看| 成人片免费看| 久久国产精品久久久久久电车 | 欧美亚洲福利| 日韩久久电影| 亚洲精选91| 久久一区欧美| 一区在线免费观看| 国产伦精品一区二区三区视频| 成人在线视频区| 亚洲在线国产日韩欧美| 久久99蜜桃| 狠狠干综合网| 国产精品一区亚洲| 久久精品卡一| 国产亚洲电影| 国产精品99一区二区| 欧美精品观看| 欧美日一区二区| 国产日韩欧美一区二区三区 | 国产精品久久久久久久久久久久久久久| 欧美久久天堂| 天堂久久av| 成人午夜国产| 国产日产精品_国产精品毛片| 天堂日韩电影| 国产精品任我爽爆在线播放| 欧美日韩国产精品一区二区亚洲| 国产精品午夜av| 国产精品毛片在线| 福利一区二区| 日本成人手机在线| 欧美a级一区| 美女精品视频在线| 亚洲激情另类| av资源中文在线天堂| 人人精品久久| 亚洲成人三区| 日本一二区不卡| 日本不卡一区二区三区| av亚洲在线观看| 狠狠久久伊人中文字幕| 一级成人国产| 亚洲午夜视频| 国产一区二区精品福利地址| 日韩国产欧美视频| 99热精品在线| 日韩中文字幕高清在线观看| 国产探花一区| 美女尤物久久精品| 三级小说欧洲区亚洲区| 国产精品激情电影| 免费成人在线视频观看| 久久久久亚洲| 国产成人精品一区二区三区视频| 亚洲精品进入| 国产亚洲精品久久久久婷婷瑜伽| 98精品久久久久久久| 国产精品网址| 日本中文字幕一区二区| 合欧美一区二区三区| 日韩久久一区二区三区| 狠狠久久伊人| 免费看久久久| 日韩一区网站| 日韩专区一卡二卡| 黄色精品网站| 激情欧美日韩一区| 日韩在线观看| www在线观看黄色| 国产一区丝袜| 精品国产一区二区三区性色av| 久久精品97| 日韩欧美激情电影| 亚洲人成在线影院| 亚洲欧美不卡| aa亚洲婷婷| 日韩亚洲在线| 亚洲精品888| 欧美日韩一二三四| 欧美日韩视频免费观看| 国产一区二区三区探花| 欧美精品aa| 日韩专区欧美专区| 午夜亚洲福利在线老司机| 欧美精品一二| 欧美特黄一级| 亚洲欧美日韩视频二区| 丝袜亚洲精品中文字幕一区| 久久福利一区|