浅谈java线程池什么时候触发拒绝策略
众所周知,线程池提交一个任务时先判断核心线程数是否有空余,没有则加入到阻塞队列中。如果阻塞队列也没有空间了,则直接开一个线程去执行。
测试
根据这个原理推测,假设核心线程数为0。
根据测试推出结论。
任务数 - 阻塞队列长度 > 最大线程数 触发拒绝策略。
任务数 > 最大线程数 + 阻塞队列长度 触发拒绝策略。
核心线程数是否影响结论
其实最大线程数可以理解为最大允许多少条线程正在执行。由此推导出
核心线程数 + (阻塞队列满了,需要再新增的线程数)
就是
核心线程数 + (任务数 - 核心线程数 - 阻塞队列长度)> 最大线程数
两个核心线程数抵消,则与上面推导的结论一致。
鄙人粗浅的认知,文中有何错误的地方可以指出,一起交流。