Java Executor執行器的飽和策略主要有以下幾種:
RejectedExecutionException
異常。以下是如何使用這些飽和策略的示例代碼:
import java.util.concurrent.*;
public class ExecutorServiceExample {
public static void main(String[] args) {
// 創建一個容量為2的隊列
BlockingQueue<Runnable> queue = new ArrayBlockingQueue<>(2);
// 使用默認的AbortPolicy
ThreadPoolExecutor executor1 = new ThreadPoolExecutor(
1, 1, 0L, TimeUnit.MILLISECONDS, queue,
new ThreadPoolExecutor.AbortPolicy());
// 使用CallerRunsPolicy
ThreadPoolExecutor executor2 = new ThreadPoolExecutor(
1, 1, 0L, TimeUnit.MILLISECONDS, queue,
new ThreadPoolExecutor.CallerRunsPolicy());
// 使用DiscardPolicy
ThreadPoolExecutor executor3 = new ThreadPoolExecutor(
1, 1, 0L, TimeUnit.MILLISECONDS, queue,
new ThreadPoolExecutor.DiscardPolicy());
// 使用DiscardOldestPolicy
ThreadPoolExecutor executor4 = new ThreadPoolExecutor(
1, 1, 0L, TimeUnit.MILLISECONDS, queue,
new ThreadPoolExecutor.DiscardOldestPolicy());
// 提交任務進行測試
for (int i = 0; i < 5; i++) {
final int taskNumber = i;
try {
executor1.submit(() -> {
System.out.println("Task " + taskNumber + " is running on thread " + Thread.currentThread().getName());
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
});
} catch (RejectedExecutionException e) {
System.out.println("Task " + taskNumber + " was rejected by AbortPolicy");
}
}
// 關閉執行器
executor1.shutdown();
executor2.shutdown();
executor3.shutdown();
executor4.shutdown();
}
}
選擇合適的飽和策略取決于具體的應用場景和需求。例如,如果需要確保所有任務都能被執行,可以選擇CallerRunsPolicy
;如果對任務丟失不敏感,可以選擇DiscardPolicy
或DiscardOldestPolicy
。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。