概述
因为篇幅太长所以分两篇博客进行说明,本文算是对《线程池提交任务和执行任务源码解析》的补充
第一篇博客《线程池提交任务和执行任务源码解析》—》https://blog.csdn.net/kznsbs/article/details/111958345
继续execute()方法的说明
public void execute(Runnable command) {
...
int c = ctl.get();
if (workerCountOf(c) < corePoolSize) {
if (addWorker(command, true))
return;
c = ctl.get();
}
//《线程池提交任务和执行任务源码解析》分析到这里
// isRunning(c):判断当前线程池是不是还在运行,如果是就会像workQueue 添加这个任务
// pivate final BlockingQueue<Runnable> workQueue;
// workQueue 就是一个阻塞队列
if (isRunning(c) && workQueue.offer(command)) {
int recheck = ctl.get();//重新获取ctl
if (! isRunning(recheck) && remove(command))//检查
reject(command);//拒绝策略
//如果正常运行,线程池没有关闭,那么进入这个判断
else if (workerCountOf(recheck) == 0)
addWorker(null, false);
}
else if (!addWorker(command, false))
reject(command);//拒绝策略
}
四种拒绝策略
rejectedExecution
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
throw new RejectedExecutionException("Task " + r.toString() +
" rejected from " +
e.toString());
}
直接抛出异常
AbortPolicy
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
if (!e.isShutdown()) {
r.run();
}
}
Runnable r : 任务
ThreadPoolExecutor e : 线程池
也就是说这个任务交给提交任务的线程处理
DiscardOldestPolicy
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
if (!e.isShutdown()) {
e.getQueue().poll();
e.execute(r);
}
}
从阻塞队列里面poll出一个任务,将新的任务添加
DiscardPolicy
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
}
不做任何处理,也就是说,代码执行到这里结束了