java ThreadPoolExecutor使用方法簡(jiǎn)單介紹
java ThreadPoolExecutor
前言:
在項(xiàng)目中如果使用發(fā)短信這個(gè)功能,一般會(huì)把發(fā)短信這個(gè)動(dòng)作變成異步的,因?yàn)榇蟛糠智闆r下,短信到底是發(fā)送成功或者失敗,都不能影響主流程。當(dāng)然像發(fā)送MQ消息等操作也是可以封裝成異步操作的。
使用基本的New Thread
如果想一個(gè)操作變成異步的,可以直接new thread,然后在run方法中實(shí)現(xiàn)業(yè)務(wù)操作即可。例如:
new Thread(new Runnable() {
public void run() {
//發(fā)短信、發(fā)MQ消息等
}
});
但是這種方式有幾個(gè)缺點(diǎn)。
1.每次都會(huì)new一個(gè)線(xiàn)程,執(zhí)行完后銷(xiāo)毀,不能復(fù)用;
2.如果系統(tǒng)的并發(fā)量剛好比較大,需要大量線(xiàn)程,那么這種每次new的方式會(huì)搶資源的。
ThreadPoolExecutor
我們可以使用jdk1.5中的ThreadPoolExecutor來(lái)封裝異步操作。ThreadPoolExecutor的好處是可以做到線(xiàn)程復(fù)用,并且使用盡量少的線(xiàn)程去執(zhí)行更多的任務(wù),效率和性能都相當(dāng)不錯(cuò)。demo代碼如下:
public class ThreadPool {
private static ThreadPoolExecutor threadPool = new ThreadPoolExecutor(8, 12, 30,
TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(50000), new ThreadPoolExecutor.AbortPolicy());
public static ThreadPoolExecutor getThreadPool() {
return threadPool;
}
}
參數(shù)介紹
public ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
RejectedExecutionHandler handler) {
}
corePoolSize:當(dāng)workQueue隊(duì)列中的元素還未到達(dá)最大值時(shí),corePoolSize表示的池中線(xiàn)程數(shù)量的最大值;
maximumPoolSize:線(xiàn)程池中允許的最大線(xiàn)程數(shù);
keepAliveTime:當(dāng)前池中的線(xiàn)程數(shù)如果超過(guò)了corePoolSize,那么超出那些線(xiàn)程如果空閑太久了,應(yīng)該需要銷(xiāo)毀的。keepAliveTime就是的是這些線(xiàn)程的最大空閑時(shí)間;
unit:keepAliveTime的時(shí)間單位;
workQueue:當(dāng)池中線(xiàn)程數(shù)的數(shù)量已經(jīng)達(dá)到了corePoolSize,那么如果請(qǐng)求還繼續(xù)過(guò)來(lái),會(huì)把請(qǐng)求對(duì)應(yīng)的task放入隊(duì)列中;
handler:當(dāng)workQueue滿(mǎn)了,池中的線(xiàn)程數(shù)又達(dá)到了maximumPoolSize,這個(gè)時(shí)候已經(jīng)沒(méi)有多余的資源處理請(qǐng)求了,需要RejectedExecutionHandler 來(lái)處理。拒絕處理或者丟棄任務(wù)等等。
執(zhí)行過(guò)程
當(dāng)沒(méi)有請(qǐng)求時(shí),線(xiàn)程池中沒(méi)有任何線(xiàn)程;
當(dāng)有請(qǐng)求時(shí),創(chuàng)建線(xiàn)程,一直到池中的線(xiàn)程數(shù)等于corePoolSize;
如果請(qǐng)求太多,需要更多的線(xiàn)程來(lái)處理的話(huà),ThreadPoolExecutor選擇把請(qǐng)求放入隊(duì)列中,暫時(shí)不新建線(xiàn)程;
如果workQueue也滿(mǎn)了,ThreadPoolExecutor會(huì)繼續(xù)創(chuàng)建線(xiàn)程,直到線(xiàn)程數(shù)量跟maximumPoolSize相等;
線(xiàn)程數(shù)達(dá)到maximumPoolSize了,同時(shí)workQueue也慢了,就只能把請(qǐng)求丟給RejectedExecutionHandler 來(lái)處理。
備注
使用ThreadPoolExecutor時(shí),需要根據(jù)自己的業(yè)務(wù)情況,適當(dāng)?shù)闹付▍?shù)值的大小。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- java 定時(shí)器線(xiàn)程池(ScheduledThreadPoolExecutor)的實(shí)現(xiàn)
- Java線(xiàn)程池ThreadPoolExecutor原理及使用實(shí)例
- java中ThreadPoolExecutor常識(shí)匯總
- Java ThreadPoolExecutor 線(xiàn)程池的使用介紹
- Java自帶定時(shí)任務(wù)ScheduledThreadPoolExecutor實(shí)現(xiàn)定時(shí)器和延時(shí)加載功能
- java ThreadPoolExecutor 并發(fā)調(diào)用實(shí)例詳解
- Java ThreadPoolExecutor的參數(shù)深入理解
- java中Executor,ExecutorService,ThreadPoolExecutor詳解
- 詳解Java并發(fā)包中線(xiàn)程池ThreadPoolExecutor
相關(guān)文章
在SpringBoot中注入RedisTemplate實(shí)例異常的解決方案
這篇文章主要介紹了在SpringBoot中注入RedisTemplate實(shí)例異常的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
springboot集成shiro詳細(xì)總結(jié)
這幾天在看 shiro,用 springboot 集成了一下,下面的這個(gè)例子中主要介紹了 shiro 的認(rèn)證和授權(quán),以及鹽值加密的功能.程序可以運(yùn)行起來(lái).這里只做一個(gè)簡(jiǎn)單的介紹,后續(xù)會(huì)針對(duì)各個(gè)功能做一個(gè)詳細(xì)的介紹,這里不做過(guò)多的贅述,需要的朋友可以參考下2021-05-05
淺談springboot之JoinPoint的getSignature方法
這篇文章主要介紹了springboot之JoinPoint的getSignature方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
詳解Java利用ExecutorService實(shí)現(xiàn)同步執(zhí)行大量線(xiàn)程
這篇文章主要介紹了Java利用ExecutorService實(shí)現(xiàn)同步執(zhí)行大量線(xiàn)程,ExecutorService可以維護(hù)我們的大量線(xiàn)程在操作臨界資源時(shí)的穩(wěn)定性。2017-03-03
java實(shí)現(xiàn)簡(jiǎn)單驗(yàn)證碼生成
這篇文章主要介紹了java實(shí)現(xiàn)簡(jiǎn)單驗(yàn)證碼生成,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
SpringBoot Admin健康檢查功能的實(shí)現(xiàn)
admin主要就是告訴運(yùn)維人員,服務(wù)出現(xiàn)異常,然后進(jìn)行通知(微信、郵件、短信、釘釘?shù)龋┛梢苑浅?焖偻ㄖ竭\(yùn)維人員,相當(dāng)報(bào)警功能,接下來(lái)通過(guò)本文給大家介紹SpringBoot Admin健康檢查的相關(guān)知識(shí),一起看看吧2021-06-06
解決idea中javaweb的mysql8.0.15配置問(wèn)題
這篇文章主要介紹了idea中javaweb的mysql8.0.15配置問(wèn)題 ,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05
mybatis配置mapper-locations位置的三種方式小結(jié)
這篇文章主要給大家介紹了關(guān)于mybatis配置mapper-locations位置的三種方式,Mybatis-Plus的初衷是為了簡(jiǎn)化開(kāi)發(fā),而不建議開(kāi)發(fā)者自己寫(xiě)SQL語(yǔ)句的,但是有時(shí)客戶(hù)需求比較復(fù)雜,需要的朋友可以參考下2023-08-08

