17.拒绝策略

       ThreadPoolExecutor的最后一个参数指定了拒绝策略,也就是当线程池中的线程已经使用完了,无法为新的任务服务,同时等待队列中也已经排满了,再也无法塞下新任务了。拒绝策略就是用来处理这个情况的。

       JDK内置了四种拒绝策略:

       1.AbortPolicy:直接抛出异常,阻止系统正常工作;

       2.CallerRunsPolicy:只要线程池未关闭,直接在调用者线程中运行当前被等待队列拒绝加入的任务。提交任务的线程的性能会急剧下降。

       3.DiscardOledestPolicy:丢弃最老的一个请求,也就是即将被执行的一个·任务,并尝试再次提交当前任务(不是最老的请求)。

       4.DiscardPolicy:丢弃无法处理的任务,不做任何处理。

       以上四种策略均是通过实现RejectedExecutionHandler接口来实现的。我们可以通过实现这个接口来自定义策略。

//r为请求执行的任务
//executor为当前的线程池
public interface RejectedExecutionHandler {
    void rejectedExecution(Runnable r,ThreadPoolExecutor executor);
}

你可能感兴趣的:(Java高并发,Java多线程基础)