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

10年積累的網(wǎng)站設(shè)計、做網(wǎng)站經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有石棉免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
1、AbortPolicy(默認策略)
2、CallerRunsPolicy
3、DiscardOldestPolicy
4、DiscardPolicy
下面是對這些策略的詳細解釋:
1. AbortPolicy(默認策略)
當(dāng)線程池和隊列都滿了,無法處理新的任務(wù)時,AbortPolicy策略會拋出一個RejectedExecutionException異常,這是默認的拒絕策略。
2. CallerRunsPolicy
當(dāng)線程池和隊列都滿了,無法處理新的任務(wù)時,CallerRunsPolicy策略會直接在調(diào)用者線程中執(zhí)行這個任務(wù),換句話說,它會將任務(wù)放回調(diào)用者的隊列中,讓調(diào)用者自己處理。
3. DiscardOldestPolicy
當(dāng)線程池和隊列都滿了,無法處理新的任務(wù)時,DiscardOldestPolicy策略會丟棄隊列中最舊的任務(wù),然后將新任務(wù)加入隊列。
4. DiscardPolicy
當(dāng)線程池和隊列都滿了,無法處理新的任務(wù)時,DiscardPolicy策略會直接丟棄新任務(wù),不做任何處理。
下面是一個簡單的示例代碼,展示了如何使用不同的拒絕策略:
import java.util.concurrent.*;
public class ThreadPoolDemo {
public static void main(String[] args) {
// 創(chuàng)建一個固定大小的線程池
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)建了一個固定大小為2的線程池,隊列大小為2,拒絕策略為AbortPolicy,然后提交了10個任務(wù),由于線程池和隊列的大小限制,最后會有8個任務(wù)被拒絕。
網(wǎng)站題目:java線程池拒絕策略
當(dāng)前鏈接:http://www.dlmjj.cn/article/dpccpcs.html


咨詢
建站咨詢
