如果你提交任务时,线程池队列已满,这时会发生什么

有俩种可能:
1、如果使用的是无界队列 LinkedBlockingQueue,也就是无界队列的话,没关系,继续添加任务到阻塞队列中等待执行,因为 LinkedBlockingQueue 可以近乎认为是一个无穷大的队列,可以无限存放任务
2、如果使用的是有界队列比如 ArrayBlockingQueue,任务首先会被添加到ArrayBlockingQueue中,ArrayBlockingQueue 满了,会根据maximumPoolSize 的值增加线程数量,如果增加了线程数量还是处理不过来,ArrayBlockingQueue 继续满,那么则会使用拒绝策略RejectedExecutionHandler处理满了的任务,默认是 AbortPolicy

补充:
线程池四大拒绝策略

、AbortPolicy
直接丢弃任务,抛出RejectedExecutionException异常,是默认策略

2、CallerRunsPolicy
只用调用者所在的线程处理任务

3、DiscardOldestPolicy
丢弃等待队列中最旧的任务,并执行当前任务

4、DiscardPolicy
直接丢弃任务,但不抛出异常
————————————————
版权声明:本文为CSDN博主「NewBee.Mu」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/NewBeeMu/article/details/122464378

————————————————
版权声明:本文为CSDN博主「NewBee.Mu」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/NewBeeMu/article/details/122464330

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容