新聞中心
Java線程池的拒絕策略是指當(dāng)任務(wù)數(shù)量超過(guò)線程池的處理能力時(shí),線程池如何處理這些額外的任務(wù),Java線程池提供了四種拒絕策略,分別是:

10年積累的網(wǎng)站設(shè)計(jì)、做網(wǎng)站經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有石棉免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
1、AbortPolicy(默認(rèn)策略)
2、CallerRunsPolicy
3、DiscardOldestPolicy
4、DiscardPolicy
下面是對(duì)這些策略的詳細(xì)解釋?zhuān)?/p>
1. AbortPolicy(默認(rèn)策略)
當(dāng)線程池和隊(duì)列都滿了,無(wú)法處理新的任務(wù)時(shí),AbortPolicy策略會(huì)拋出一個(gè)RejectedExecutionException異常,這是默認(rèn)的拒絕策略。
2. CallerRunsPolicy
當(dāng)線程池和隊(duì)列都滿了,無(wú)法處理新的任務(wù)時(shí),CallerRunsPolicy策略會(huì)直接在調(diào)用者線程中執(zhí)行這個(gè)任務(wù),換句話說(shuō),它會(huì)將任務(wù)放回調(diào)用者的隊(duì)列中,讓調(diào)用者自己處理。
3. DiscardOldestPolicy
當(dāng)線程池和隊(duì)列都滿了,無(wú)法處理新的任務(wù)時(shí),DiscardOldestPolicy策略會(huì)丟棄隊(duì)列中最舊的任務(wù),然后將新任務(wù)加入隊(duì)列。
4. DiscardPolicy
當(dāng)線程池和隊(duì)列都滿了,無(wú)法處理新的任務(wù)時(shí),DiscardPolicy策略會(huì)直接丟棄新任務(wù),不做任何處理。
下面是一個(gè)簡(jiǎn)單的示例代碼,展示了如何使用不同的拒絕策略:
import java.util.concurrent.*;
public class ThreadPoolDemo {
public static void main(String[] args) {
// 創(chuàng)建一個(gè)固定大小的線程池
ThreadPoolExecutor executor = new ThreadPoolExecutor(2, 4, 60, TimeUnit.SECONDS,
new ArrayBlockingQueue<>(2), new ThreadPoolExecutor.AbortPolicy());
// 提交任務(wù)
for (int i = 0; i < 10; i++) {
executor.execute(new Runnable() {
@Override
public void run() {
System.out.println("Task executed by: " + Thread.currentThread().getName());
}
});
}
// 關(guān)閉線程池
executor.shutdown();
}
}
在上面的代碼中,我們創(chuàng)建了一個(gè)固定大小為2的線程池,隊(duì)列大小為2,拒絕策略為AbortPolicy,然后提交了10個(gè)任務(wù),由于線程池和隊(duì)列的大小限制,最后會(huì)有8個(gè)任務(wù)被拒絕。
當(dāng)前名稱(chēng):java線程池拒絕策略
文章出自:http://m.fisionsoft.com.cn/article/dpccpcs.html


咨詢
建站咨詢
