[Q&A] 什么是饱和策略?
RejectedExecutionHandler
(饱和策略):当队列和线程池都满了,说明线程池处于饱和状态,那么必须采取一种策略处理提交的新任务。
[Q&A] 常见饱和策略?
ThreadPoolExecutor.AbortPolicy(默认)
# 直接抛出RejectedExecutionException来拒绝新任务的处理。
ThreadPoolExecutor.DiscardPolicy
# 不处理,不报错,丢弃掉
ThreadPoolExecutor.DiscardOldestPolicy
# 将队列中最旧的任务(即最早提交的任务)移出队列,以便为新任务腾出空间。
ThreadPoolExecutor.CallerRunsPolicy
# 不进入线程池执行,任务将由调用者线程去执行。也就是直接在调用execute方法的线程中运行被拒绝的任务。
自定义策略
# 以根据应用场景需要来实现RejectedExecutionHandler接口自定义策略。
-----------------------------------------------------------------------------摘自 书名:Java并发编程的艺术 作者:方腾飞;魏鹏;程晓明