亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java線程池參數(shù)自定義設(shè)置詳解

 更新時(shí)間:2023年11月15日 10:11:54   作者:zhongh?Jim  
這篇文章主要為大家介紹了java線程池參數(shù)自定義設(shè)置詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

引言

上一篇線程池+ FutureTask異步執(zhí)行多任務(wù)只介紹了怎么搭配使用線程池,但沒有說明里面的線程池的參數(shù)是怎么設(shè)置的,那么本文就說明一下。

這里把上篇文章的線程池參數(shù)設(shè)置貼出來:

//給這個(gè)接口的線程池定義里邊的線程名字
ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("thread-start-runner-%d").build();
ExecutorService taskExe= new ThreadPoolExecutor(10,20,800L, TimeUnit.MILLISECONDS,new LinkedBlockingQueue<Runnable>(100),namedThreadFactory);

這些參數(shù)也不都是隨意設(shè)置的,而是有一定的考量思路,下面會(huì)一 一介紹

先介紹一下線程池的構(gòu)造函數(shù)

public ThreadPoolExecutor(int corePoolSize,
                          int maximumPoolSize,
                          long keepAliveTime,
                          TimeUnit unit,
                          BlockingQueue<Runnable> workQueue,
                          ThreadFactory threadFactory,
                          RejectedExecutionHandler handler) {
    ...
}

我們創(chuàng)建線程池一般是手動(dòng)設(shè)置線程池的參數(shù),已經(jīng)不建議使用Executors的FixedThreadPool 、SingleThreadPool、CachedThreadPool了

因?yàn)椋?/p>

  • FixedThreadPool 、SingleThreadPool會(huì)的任務(wù)等待隊(duì)列均為new LinkedBlockingQueue<Runnable>(),允許的隊(duì)列長度為 Integer.MAX_VALUE,存在任務(wù)堆積導(dǎo)致OOM內(nèi)存溢出的隱患
  • 而CachedThreadPool允許的最大線程數(shù)量為Integer.MAX_VALUE,而且核心線程數(shù)為0,意味著 只要有任務(wù)進(jìn)來,就會(huì)頻繁創(chuàng)建新線程,沒有任務(wù)之后又要關(guān)閉線程,耗費(fèi)性能。另一方面,由于允許創(chuàng)建大量的線程,也有導(dǎo)致OOM的潛在隱患

設(shè)置線程池參數(shù)需要參考幾個(gè)數(shù)值:

tasks:每秒任務(wù)數(shù),運(yùn)維反饋是平均每秒 38個(gè)

taskcost:每個(gè)任務(wù)花費(fèi)時(shí)間,0.2s

(3) responsetime:系統(tǒng)容忍(線程等待最長時(shí)間)的最大時(shí)間1s

corePoolSize:核心線程數(shù)

核心線程會(huì)一直存活,不管空不空閑,但如果設(shè)置了setAllowCoreThreadTimeout(true)會(huì)讓核心線程在空閑超時(shí)后關(guān)閉

計(jì)算方式:corePoolSize=tasks/(1/taskcost) =tasks * taskcost =38*0.2=7.6 個(gè)

查閱了下文章,大佬說計(jì)算密集型(遍歷+判斷的邏輯耗時(shí)占比多)的接口可將核心線程設(shè)置為:

corePoolSize=CPU核數(shù)+1 =8+1=9,設(shè)置為10就好了

如何查看CPU核數(shù):

System.out.println(Runtime.getRuntime().availableProcessors());

設(shè)置得稍微大一點(diǎn),也能減少頻繁創(chuàng)建額外線程帶來的開銷

maxPoolSize:最大線程數(shù)

如果核心線程數(shù)不夠用,會(huì)創(chuàng)建額外的線程來執(zhí)行任務(wù)。

創(chuàng)建額外線程的條件(缺一不可):

  • 現(xiàn)有的線程數(shù)< 最大線程數(shù)maxPoolSize and 現(xiàn)有線程數(shù) > corePoolSize核心線程數(shù)
  • 任務(wù)隊(duì)列填滿了

最大線程數(shù)我們設(shè)置的相對隨意了些, 令maxPoolSize= 2* corePoolSize=20,大概能應(yīng)對突然暴增的業(yè)務(wù)查詢請求

keepAliveTime額外線程的可空閑時(shí)間

額外線程就是在核心線程數(shù)的基礎(chǔ)上 另外創(chuàng)建的線程

額外線程空閑了keepAliveTime的時(shí)間后,線程退出,直至現(xiàn)有的線程數(shù)量=corePoolSize核心線程數(shù)

  • TimeUnit.MILLISECONDS是毫秒單位

workQueue任務(wù)隊(duì)列

常見的有3種:

(1) 無限隊(duì)列LinkedBlockingQueue()

構(gòu)造函數(shù)是new LinkedBlockingQueue<Runnable>()

允許的任務(wù)等待隊(duì)列的最大長度為:Integer.MAX_VALUE,即能無限的接收新的任務(wù),任何的拒絕策略也差不多沒有意義了。

另外,maximumPoolSize這個(gè)參數(shù)也沒有意義了,因?yàn)橹挥型瑫r(shí)滿足 核心線程數(shù)量夠了 + 任務(wù)隊(duì)列workQueue滿了 + 現(xiàn)有的線程數(shù)<maximumPoolSize最大線程數(shù),才會(huì)去創(chuàng)建額外的線程

  • 好處是LinkedBlockingQueue在應(yīng)對突然暴增的請求時(shí),它不會(huì)拋異常拒絕
  • 缺點(diǎn)是任務(wù)堆積過度沒有及時(shí)處理的話,容易導(dǎo)致內(nèi)存溢出

那咱們就不用這個(gè)隊(duì)列了吧

(2) 有界隊(duì)列

  • new LinkedBlockingQueue(int capacity):固定容量的阻塞隊(duì)列
  • new ArrayBlockingQueue<Integer>(int capacity,true);其中true是公平鎖,只能FIFO排隊(duì)一 一執(zhí)行;false允許任務(wù)插隊(duì),會(huì)存在晚來的任務(wù)先執(zhí)行的情況
  • PriorityBlockingQueue(int initialCapacity, Comparator<? super E> comparator):默認(rèn)會(huì)創(chuàng)建長度為11的優(yōu)先級(jí)隊(duì)列,第二個(gè)參數(shù)comparator會(huì)按照我們指定的方式進(jìn)行排序

我們的任務(wù)基本的執(zhí)行順序基本也是先進(jìn)先出,直接用了new LinkedBlockingQueue(int capacity),把容量設(shè)置得大一點(diǎn),那樣就不會(huì)輕易的填滿隊(duì)列導(dǎo)致頻繁地創(chuàng)建額外的線程,減少線程頻繁切換

(3) SynchronousQueue

new SynchronousQueue():隊(duì)列長度為0,要添加新任務(wù)必須得有空閑的線程才能添加,因此要求 maximumPoolSize盡可能的大,還得 配置拒絕策略

最終, 我們選擇了new LinkedBlockingQueue(int capacity)作為任務(wù)隊(duì)列

任務(wù)隊(duì)列的長度

queueCapacity = (coreSize/taskcost) * responsetime=8/0.2*1=80,隊(duì)列長度設(shè)置為100也可

RejectedExecutionHandler拒絕策略

  • AbortPolicy:拋異常
  • DiscardPolicy:丟任務(wù)
  • DiscardOldestPolicy:將隊(duì)列頭部的任務(wù)丟了,也就是把最早進(jìn)入隊(duì)列等待的任務(wù)丟了
  • CallerRunsPolicy:將新任務(wù)(皮球)踢回給主線程執(zhí)行,讓主線程在接下來的時(shí)間能無法提交新任務(wù),典型的踢皮球策略

我們選擇了默認(rèn)的AbortPolicy拋異常:

拋異常的話,需要上游系統(tǒng)截獲異常,并告知用戶請求繁忙稍等一下

如果是DiscardPolicy丟任務(wù)的話我猜大概率是用戶得不到響應(yīng)吧,沒這么搞過

線程工廠

它還是很有必要設(shè)置的,因?yàn)橄到y(tǒng)的線程池不止一個(gè),不設(shè)置一下線程工廠,不給線程定義個(gè)名字的話,很難看到是哪個(gè)線程池的線程在跑,因?yàn)榫€程的名字都被寫死成pool-1-thread-1pool-1-thread-2、pool-2-thread-1

那么,問題來了:如何判斷線程池里邊的指定線程是否在執(zhí)行任務(wù)?

更多關(guān)于線程池參數(shù)自定義的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Struts2 自定義下拉框Tag標(biāo)簽

    Struts2 自定義下拉框Tag標(biāo)簽

    這篇文章主要介紹了Struts2 自定義下拉框Tag標(biāo)簽的相關(guān)資料,需要的朋友可以參考下
    2016-02-02
  • MyBatis創(chuàng)建存儲(chǔ)過程的實(shí)例代碼_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    MyBatis創(chuàng)建存儲(chǔ)過程的實(shí)例代碼_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    本節(jié)需要用到的有2部分,第一部分是如何在Derby中創(chuàng)建存儲(chǔ)過程,第二部分是如何在Mybatis中調(diào)用存儲(chǔ)過程,具體實(shí)例代碼大家參考下本文吧
    2017-09-09
  • Spring多線程的使用以及問題詳解

    Spring多線程的使用以及問題詳解

    在我們開發(fā)系統(tǒng)過程中,經(jīng)常會(huì)處理一些費(fèi)時(shí)間的任務(wù)(如:向數(shù)據(jù)庫中插入大量數(shù)據(jù)),這個(gè)時(shí)候就就需要使用多線程,下面這篇文章主要給大家介紹了關(guān)于Spring多線程的使用以及問題的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • Spring?依賴注入和循環(huán)依賴的實(shí)例解析

    Spring?依賴注入和循環(huán)依賴的實(shí)例解析

    依賴注入的主要目的是降低類之間的耦合度,使得代碼更加靈活、可維護(hù)和可測試,這篇文章主要介紹了Spring?依賴注入和循環(huán)依賴的相關(guān)知識(shí),需要的朋友可以參考下
    2023-09-09
  • Mybatis select記錄封裝的實(shí)現(xiàn)

    Mybatis select記錄封裝的實(shí)現(xiàn)

    這篇文章主要介紹了Mybatis select記錄封裝的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • java?設(shè)計(jì)模式從風(fēng)控鏈理解責(zé)任鏈模式

    java?設(shè)計(jì)模式從風(fēng)控鏈理解責(zé)任鏈模式

    這篇文章主要為大家介紹了java?設(shè)計(jì)模式從風(fēng)控鏈理解責(zé)任鏈模式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • IDEA性能優(yōu)化設(shè)置(解決卡頓問題)

    IDEA性能優(yōu)化設(shè)置(解決卡頓問題)

    在我們?nèi)粘J褂肐DEA進(jìn)行開發(fā)時(shí),可能會(huì)遇到許多卡頓的瞬間,本文主要介紹了IDEA性能優(yōu)化設(shè)置,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2023-05-05
  • 解決springboot的aop切面不起作用問題(失效的排查)

    解決springboot的aop切面不起作用問題(失效的排查)

    這篇文章主要介紹了解決springboot的aop切面不起作用問題(失效的排查),具有很好的參考價(jià)值,希望對大家有所幫助。 一起跟隨小編過來看看吧
    2020-04-04
  • SpringBoot實(shí)現(xiàn)PPT格式文件上傳并在線預(yù)覽功能

    SpringBoot實(shí)現(xiàn)PPT格式文件上傳并在線預(yù)覽功能

    本文介紹SpringBoot實(shí)現(xiàn)PPT格式文件上傳并在線預(yù)覽功能,通過上傳接口,可在C盤的tempfile目錄下找到上傳的文件,預(yù)覽時(shí)會(huì)在同級(jí)目錄下創(chuàng)建一個(gè)相同文件名后綴為pdf的文件,每次預(yù)覽會(huì)先查找文件是否存在,存在則直接預(yù)覽,不存在則會(huì)走上面的處理,需要的朋友可以參考下
    2022-02-02
  • Java hashCode原理以及與equals()區(qū)別聯(lián)系詳解

    Java hashCode原理以及與equals()區(qū)別聯(lián)系詳解

    在 Java 應(yīng)用程序執(zhí)行期間,在同一對象上多次調(diào)用 hashCode 方法時(shí),必須一致地返回相同的整數(shù),前提是對象上 equals 比較中所用的信息沒有被修改。從某一應(yīng)用程序的一次執(zhí)行到同一應(yīng)用程序的另一次執(zhí)行,該整數(shù)無需保持一致
    2022-11-11

最新評論