Java线程池有4种内置拒绝策略:1. AbortPolicy抛异常,适用于支付等关键业务;2. CallerRunsPolicy由调用线程执行,实现降速,适合非实时任务;3. DiscardPolicy静默丢弃,用于可丢失任务;4. DiscardOldestPolicy丢弃最老任务,适用于新数据价值更高的场景。
Java线程池常见的拒绝策略有4种,全部内置在 ThreadPoolExecutor 中,实现 RejectedExecutionHandler 接口。它们在任务无法入队、也无法扩容线程时被触发,行为和适用场景差异明显。
当线程池已满(线程数达 maximumPoolSize 且工作队列已满),新任务会被拒绝,并立即抛出 RejectedExecutionException。
拒绝发生时,不丢任务、不抛异常,而是让调用 execute() 的线程(比如主线程)同步执行该任务。
务新任务直接被忽略,既不执行也不抛异常,控制台无任何输出。
先从工作队列头部移除一个等待最久的任务(FIFO 队列中即最早入队的),然后重新尝试将当前任务加入队列。
poll() 操作(如 ArrayBlockingQueue、LinkedBlockingQueue)选哪种策略,关键看三件事:任务能不能丢、要不要立刻知道失败、是否允许调用线程变慢。实际项目中,也常结合自定义策略——比如记录拒绝日志 + 上报 Prometheus 指标 + 触发限流开关。