线程池构造函数参数有哪些
- 核心线程池
- 最大线程数
- 空闲非核心线程存活时长
- 空闲非核心线程存活时长单位
- 阻塞队列
- 线程生产工厂
- 拒绝执行处理类
execute和submit有什么区别?
- execute会抛出异常
- submit不会抛出异常
线程池怎么处理异常
- 方式一:继承线程池,重写execute/submit,并使用try catch处理异常
- 方式二:重写线程生产工厂,给每个生产的线程类设置UncaughtExceptionHandler
如果想要在执行过程中把ThreadLocal参数进行传递,该怎么操作?
- 继承线程池类
- 重写submit方法
- 在submit的时候将ThreadLocal/MDC参数,提取并放到Runnable的私有属性中
- 在Runnable中的run方法执行的时候,将私有属性中的ThreadLocal参数或者MDC参数放到当前线程的ThreadLocal或者MDC中
- run方法执行结束后,需要把当前线程中ThreadLocal参数或者MDC参数清空
线程池的执行过程
- 当有任务提交的时候,检查核心线程是否满了
- 没满,启动新的线程进行执行
- 满了,则将任务放到阻塞队列中去
- 当阻塞队列满了,检查线程数是否已经到达最大线程数
- 没到达最大线程数,启动新的线程处理任务
- 满了,调用拒绝执行处理类进行处理
线程池
- 类:ThreadPoolExecutor