项目中使用的线程池的地方很多,一直以来感觉对它的参数已经掌握的很好了,但是遇到几次问题之后才发现欠缺的这么多
遇到的坑
任务提交后长时间没有执行
任务进入了队列,线程还在执行之前的任务。本质原因是对线程和队列的优先级认识不深刻,有一种错觉以为是所有线程都忙的时候才进入任务队列。实际上相反,是队列满的时候才会新建线程(线程数大于core size时)。
线程池中线程执行任务中无故消失(从日志可以看出,任务并未完成,也没有抛出异常)
一般情况下,代码中只会去捕捉RuntimeException,如果抛出Error则会导致线程退出,而异常信息又没有拿到。最佳的解决办法是给线程池设置UncaughtExceptionHandler
回顾线程池重要的配置
线程池参数
corePoolSize:核心线程数量
maximumPoolSize:最大线程数量
workQueue:等待队列
任务提交时,判断的顺序为 corePoolSize --> workQueue --> maximumPoolSize。
这个顺序一定不要弄错了
拒绝策略
RejectedExecutionHandler
AbortPolicy:直接抛出异常,这是默认策略
CallerRunsPolicy:用调用者所在的线程来执行任务
DiscardOldestPolicy:丢弃阻塞队列中靠最前的任务,并执行当前任务
DiscardPolicy:直接丢弃任务
默认是抛出异常,除非想得特别清楚,不然