真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

java中ThreadPoolExecutor知識有哪些

本篇內容介紹了“java中ThreadPoolExecutor知識有哪些”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

創(chuàng)新互聯(lián)建站是一家集網站建設,天臺企業(yè)網站建設,天臺品牌網站建設,網站定制,天臺網站建設報價,網絡營銷,網絡優(yōu)化,天臺網站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網站。

線程池技術在并發(fā)時經常會使用到,java中的線程池的使用是通過調用ThreadPoolExecutor來實現(xiàn)的。ThreadPoolExecutor提供了四個構造函數(shù),最后都會歸結于下面這個構造方法:

// 七個參數(shù)的構造函數(shù)public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handler)

這些參數(shù)的意義如下:

corePoolSize:該線程池中核心線程數(shù)最大值  maximumPoolSize: 該線程池中線程總數(shù)最大值  keepAliveTime:該線程池中非核心線程閑置超時時長  unit:keepAliveTime的單位  workQueue:阻塞隊列BlockingQueue,維護著等待執(zhí)行的Runnable對象  threadFactory:創(chuàng)建線程的接口,需要實現(xiàn)他的Thread newThread(Runnable r)方法。  RejectedExecutionHandler:飽和策略,最大線程和工作隊列容量且已經飽和時execute方法都將調用RejectedExecutionHandler 。

ThreadPoolExecutor工作流程

流程圖如下:

大致過程陳述為:

  1. 向線程池中添加任務,當任務數(shù)量少于corePoolSize時,會自動創(chuàng)建thead來處理這些任務;  當添加任務數(shù)大于corePoolSize且少于maximmPoolSize時,不在創(chuàng)建線程,而是將這些任務放到阻塞隊列中,等待被執(zhí)行;  接上面2的條件,且當阻塞隊列滿了之后,繼續(xù)創(chuàng)建thread,從而加速處理阻塞隊列;  當添加任務大于maximmPoolSize時,根據(jù)飽和策略決定是否容許繼續(xù)向線程池中添加任務,默認的飽和策略是AbortPolicy(直接丟棄)。

線程池中使用的阻塞隊列

ArrayBlockingQueue:基于數(shù)組結構的有界阻塞隊列,構造函數(shù)一定要傳大小,F(xiàn)IFO(先進先出);  LinkedBlockingQueue:無界,默認大小65536(Integer.MAX_VALUE),當大量請求任務時,容易造成內存耗盡。  SynchronousQueue:同步隊列,是一個特殊的BlockingQueue,它沒有容量(這是因為在SynchronousQueue中,插入將等待另一個線程的刪除操作,反之亦然)。  DelayedWorkQueue:這個隊列接收到任務時,首先先入隊,只有達到了指定的延時時間,才會執(zhí)行任務

阻塞隊列常見的方法如下表所示:

add      增加一個元索      如果隊列已滿,則拋出一個IIIegaISlabEepeplian異常              remove      移除并返回隊列頭部的元素      如果隊列為空,則拋出一個NoSuchElementException異常              element      返回隊列頭部的元素      如果隊列為空,則拋出一個NoSuchElementException異常              offer      添加一個元素并返回true      如果隊列已滿,則返回false              poll      移除并返問隊列頭部的元素      如果隊列為空,則返回null              peek      返回隊列頭部的元素      如果隊列為空,則返回null              put      添加一個元素      如果隊列滿,則阻塞              take      移除并返回隊列頭部的元素      如果隊列為空,則阻塞

常見四種線程池

newCachedThreadPool  newFixedThreadPool  newSingleThreadExecutor  newScheduledThreadPool

CachedThreadPool      SynchronousQueue(隊列長度無限      可增加,最大值Integer.MAX_VALUE      默認60秒超時              FixedThreadPool      LinkedBlockingQueue(隊列長度無限)      可指定nThreads,固定數(shù)量      不會超時              newSingleThreadExecutor      LinkedBlockingQueue(隊列長度無限),      固定為1      不超時              newScheduledThreadPool      DelayedWorkQueue      可增加,最大值Integer.MAX_VALUE      不超時

它們通過Executors以靜態(tài)方法的方式直接調用,實質上是它們最終調用的是ThreadPoolExecutor的構造方法,也就是本文最前面那段代碼。

注:KeepAliveTime=0的話,表示不等待

《阿里巴巴java開發(fā)手冊》中建議線程池不使用 Executors 去創(chuàng)建,而是通過 ThreadPoolExecutor的方式,這樣的處理方式讓寫的人員更加明確線程池的運行規(guī)則,規(guī)避資源耗盡的風險。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持我們。

本文標題: java中ThreadPoolExecutor常識匯總

方法名說明注意
線程池使用的阻塞隊列線程池大小超時

“java中ThreadPoolExecutor知識有哪些”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網站,小編將為大家輸出更多高質量的實用文章!


網站名稱:java中ThreadPoolExecutor知識有哪些
文章位置:http://weahome.cn/article/gdhioi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部