有2种原因可能导致此异常。
第一:
你的线程池ThreadPoolExecutor 显示的shutdown()之后,再向线程池提交任务的时候。如果你配置的拒绝策略是AbortPolicy的话,这个异常就会抛出来。
第二:
队列满了,而且池中的线程数也达到了最大线程数,所以新添加的任务被拒绝了。
这种情况,可以调整一下线程池的策略
handler有四个选择:
ThreadPoolExecutor.AbortPolicy() //缺省策略
抛出java.util.concurrent.RejectedExecutionException异常
ThreadPoolExecutor.CallerRunsPolicy()
重试添加当前的任务,他会自动重复调用execute()方法
ThreadPoolExecutor.DiscardOldestPolicy()
抛弃旧的任务
ThreadPoolExecutor.DiscardPolicy()
抛弃当前的任务
所以你根据情况,调整,即
ThreadPoolExecutor threadPool = new ThreadPoolExecutor(
BLOCK_SIZE, BLOCK_SIZE * 2, Long.MAX_VALUE, TimeUnit.SECONDS, queue);
threadPool.setRejectedExecutionHandler(ThreadPoolExecutor.CallerRunsPolicy);
或者,采用无界队列,也就不会出现任务满的情况了
即,把queue换成LinkedBlockingQueue,不过这种情况,你的最大线程数就没意义了,只会保持核心线程数在运行