日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

java.util.concurrent.RejectedExecutionException

發(fā)布時(shí)間:2025/3/8 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java.util.concurrent.RejectedExecutionException 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

2019獨(dú)角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>

遇到j(luò)ava.util.concurrent.RejectedExecutionException

目前看來(lái),最主要有2種原因。
第一:
你的線(xiàn)程池ThreadPoolExecutor 顯示的shutdown()之后,再向線(xiàn)程池提交任務(wù)的時(shí)候。 如果你配置的拒絕策略是AbortPolicy的話(huà),這個(gè)異常就會(huì)拋出來(lái)。
第二:
當(dāng)你設(shè)置的任務(wù)緩存隊(duì)列過(guò)小的時(shí)候,或者說(shuō), 你的線(xiàn)程池里面所有的線(xiàn)程都在干活(線(xiàn)程數(shù)== maxPoolSize),并且你的任務(wù)緩存隊(duì)列也已經(jīng)充滿(mǎn)了等待的隊(duì)列, 這個(gè)時(shí)候,你再向它提交任務(wù),則會(huì)拋出這個(gè)異常。

下面用例子來(lái)說(shuō)明一下,兩種情況:

第一種, 顯示關(guān)閉掉了線(xiàn)程池
這一點(diǎn)其實(shí)理解起來(lái)很簡(jiǎn)單, 比如說(shuō),你向一個(gè)倉(cāng)庫(kù)去存放貨物,一開(kāi)始,倉(cāng)庫(kù)管理員把門(mén)給你打開(kāi)了,你放了第一件商品到倉(cāng)庫(kù)里面,但是當(dāng)你放好出去的時(shí)候,不小心把倉(cāng)庫(kù)的門(mén)關(guān)掉了, 那么你下次再來(lái)存放的時(shí)候, 你就會(huì)被拒絕掉。
落實(shí)到代碼就是:

ThreadPoolExecutor EXECUTOR = new ThreadPoolExecutor(5, 10, 3000L, TimeUnit.MILLISECONDS,??new LinkedBlockingQueue<Runnable>(4));?

??????for (int i = 0; i < 2; i++) {?

??????????EXECUTOR.execute(new Runnable() {?

??????????????public void run() {?

??????????????????System.out.println("Hello World");?

??????????????}?

??????????});?

??????????EXECUTOR.shutdown();?

??????}

?

01ThreadPoolExecutor EXECUTOR =?new?ThreadPoolExecutor(5,?10, 3000L, TimeUnit.MILLISECONDS,
02??????????????????????????????????????????????????????????new?LinkedBlockingQueue<Runnable>(4));
03?????for?(int?i =?0; i <?2; i++) {
04?????????EXECUTOR.execute(new?Runnable() {
05?????????????public?void?run() {
06?????????????????System.out.println("Hello World");
07?????????????}
08?????????});
09?????????EXECUTOR.shutdown();
10?????}

如上, 在我們提交第一個(gè)任務(wù)之后,線(xiàn)程池就被關(guān)閉掉了。 那么你再向線(xiàn)程池提交新任務(wù)的時(shí)候,你就會(huì)遇到類(lèi)似的異常。
為什么會(huì)這樣?
原因是,在ThreadPoolExecutor內(nèi)部,存放著當(dāng)前這個(gè)線(xiàn)程池的運(yùn)行狀態(tài)。
當(dāng)你調(diào)用shutdown的時(shí)候, 線(xiàn)程池會(huì)有順序的將線(xiàn)程池中正在運(yùn)行的任務(wù)給關(guān)閉掉。InterruptException這樣的異常。

第二種代碼如下:

for (int i = 0; i < 15; i++) {?

?????????final int tmpint=i;?

?????????EXECUTOR.execute(new Runnable() {?

?????????????public void run() {?

?????????????????try {?

?????????????????????System.out.println(tmpint+"Hello World");?

?????????????????????Thread.sleep(1000);?

?????????????????} catch (InterruptedException e) {?

?????????????????}?

?????????????}?

?????????});?

?????}

?

01for?(int?i =?0; i <?15; i++) {
02?????????final?int?tmpint=i;
03?????????EXECUTOR.execute(new?Runnable() {
04?????????????public?void?run() {
05?????????????????try?{
06?????????????????????System.out.println(tmpint+"Hello World");
07?????????????????????Thread.sleep(1000);
08?????????????????}?catch?(InterruptedException e) {
09?????????????????}
10?????????????}
11?????????});
12?????}

類(lèi)似的,當(dāng)你的線(xiàn)程池中 ,正在執(zhí)行包括正在等待的線(xiàn)程數(shù)有 maxPool + workQueueSize 這個(gè)數(shù)量的話(huà)。 再次向它提交任務(wù),則會(huì)遇到這個(gè)異常。
比如,上面的線(xiàn)程數(shù): 如果當(dāng)前線(xiàn)程正在跑的數(shù)量 <最大線(xiàn)程, 再加上等待的, 都有我們的業(yè)務(wù)點(diǎn)嗎?

解決辦法:
針對(duì)第一種,可以再往線(xiàn)程池存放線(xiàn)程之前先判斷線(xiàn)程池是否已經(jīng)關(guān)閉

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ExecutorServiceDemo {

?static class MyThread implements Runnable {

??public void run() {
???try {
????Thread.sleep(500);
????// System.out.println("MyThread...");
???} catch (InterruptedException e) {
????e.printStackTrace();
???}
??}
?}

?public static void main(String[] args) {

??ExecutorService pool = Executors.newFixedThreadPool(20);
??
??System.out.println("pool start ...");
??
??for (int i = 0; i < 1000; i++) {
???
???try {

????if(!pool.isShutdown()){
?????
?????pool.execute(new MyThread());
????}

????if (i == 300) {
?????
?????pool.shutdown();
????}
????
???} catch (Exception e) {
????
????e.printStackTrace();
???}
??}
??System.out.println("pool end ...");
?}
}

第二種:
可以將線(xiàn)程池的數(shù)量調(diào)大點(diǎn)(minPoolSize,maxPoolSize,handlerList)這新信息。


轉(zhuǎn)載于:https://my.oschina.net/u/1244156/blog/208463

總結(jié)

以上是生活随笔為你收集整理的java.util.concurrent.RejectedExecutionException的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。