有自己的拒绝策略,当任务队列满了,线程数也达到最大的时候,需要拒绝提交的任务 。
线程池参数介绍
【自己动手写线程池——向JDK线程池进发】 private AtomicInteger ct = new AtomicInteger(0); // 当前在执行任务的线程个数 private int corePoolSize; private int maximumPoolSize; private long keepAliveTime; private TimeUnit unit; private BlockingQueue<Runnable> taskQueue; private RejectPolicy policy; private ArrayList<Worker> workers = new ArrayList<>(); private volatile boolean isStopped; private boolean useTimed;参数解释如下:
- ct:表示当前线程池当中线程的个数 。
- corePoolSize:线程池当中核心线程的个数,意义和上面谈到的JDK的线程池意义一致 。
- maximumPoolSize:线程池当中最大的线程个数,意义和上面谈到的JDK的线程池意义一致 。
- keepAliveTime 和 unit:和JDK线程池的参数意义一致 。
- taskQueue:任务队列,用不保存提交的任务 。
- policy:拒绝策略,主要有一下四种策略:
public enum RejectPolicy { ABORT, CALLER_RUN, DISCARD_OLDEST, DISCARD}
- workers:用于保存工作线程 。
- isStopped:线程池是否被关闭了 。
- useTimed:主要是用于表示是否使用上面的 keepAliveTime 和 unit,如果使用就是在一定的时间内,如果没有从任务队列当中获取到任务,线程就从线程池退出,但是需要保证线程池当中最小的线程个数不小于 corePoolSize。
实现Runnable // 下面这个方法是向线程池提交任务 public void execute(Runnable runnable) throws InterruptedException { checkPoolState(); if (addWorker(runnable, false) // 如果能够加入新的线程执行任务 加入成功就直接返回 || !taskQueue.offer(runnable) // 如果 taskQueue.offer(runnable) 返回 false 说明提交任务失败 任务队列已经满了 || addWorker(runnable, true)) // 使用能够使用的最大的线程数 (maximumPoolSize) 看是否能够产生新的线程 return; // 如果任务队列满了而且不能够加入新的线程 则拒绝这个任务 if (!taskQueue.offer(runnable)) reject(runnable); }在上面的代码当中:
- checkPoolState函数是检查线程池的状态,当线程池被停下来之后就不能够在提交任务:
private void checkPoolState() { if (isStopped) { // 如果线程池已经停下来了,就不在向任务队列当中提交任务了 throw new RuntimeException("thread pool has been stopped, so quit submitting task"); } }
- addWorker函数是往线程池当中提交任务并且产生一个线程,并且这个线程执行的第一个任务就是传递的参数 。max表示线程的最大数目,max == true 的时候表示使用 maximumPoolSize 否则使用 corePoolSize,当返回值等于 true 的时候表示执行成功,否则表示执行失败 。
经验总结扩展阅读
-
算命婚姻,2020年下元节后一天是安葬逝者吉日吗,安葬逝者注意什么?
-
蜜蜡对身体有什么好处,佩戴蜜蜡对身体有什么好处 戴蜜蜡有什么好处
-
-
微信聊天照片误删可以恢复吗,微信上好友发的照片误删了怎么恢复
-
-
化妆品|开皮肤管理店,自己不够专业,自主学习没有头绪!
-
-
65岁爷爷常去集市买的3款白酒,当时没钱不常喝,现在很难再见了
-
-
为什么第一眼喜欢的人,做不了朋友?眼缘这种东西,就是很神奇
-
抗癌 获得5倍抗癌功效!把这种食材加入小吃中,抗癌、减肥、护心效果翻倍!
-
一本情感簿|《闯关东》里的“厄运体”姑娘:这个苦命女人,真的是“作”?
-
-
-
-
-
植物大战僵尸怎么重新玩(植物大战僵尸通关后重新打)
-
-
-
在快节奏生活状态下 在快节奏生活状态下,一眼定恋情的人越来越多