一、使用线程池的好处
降低资源消耗,提高响应速度,提高线程的客观理性。
二、ThreadPoolExecutor的核心参数
corePoolSize:核心线程数
maximumPoolSize:最大线程数
workQueue:任务队列,当线程数量已经达到,corePoolSize时,新的任务会加入该队列。
keepAliveTime:存活时间,即空闲的线程经过多久会被回收掉
unit:keepAliveTime的时间单位
threadFactory:创建线程的工厂
handler:拒绝策略(饱和策略),下面解释。
三、ThreadPoolExecutor的工作流程
四、ThreadPoolExecutor的四种拒绝策略
当线程池的线程数量已经达到线程池配置的最大线程数时,再有任务进入时会执行拒绝策略。
①AbortPolicy:抛出RejectExecution的异常
②CallerRunsPolicy:将被拒绝的任务直接在调用者线程中执行,这样能保证任务不丢失,但会影响执行速度
③DiscardPolicy:直接丢弃该任务
④DiscardOldestPolicy:丢弃最早未处理的任务。