ThreadPoolExcutor: java.util.concurrent
一 作用:
因为线程的创建和销毁会耗费资源,所有为了保持线程的复用性,降低CPU/IO/网络的资源消耗,使用线程池来管理线程
二 核心参数:
1 corepoolsize:核心线程数
创建线程池后,线程池中线程数为0,有任务来时才创建线程去执行任务。当线程池中线程数目=corepoolsize,到达的任务会放 到缓存队列里面。
2 maxmumpoolsize:最大线程数
线程池能容纳的最大线程数。
3 keepalivetime 最大空闲时间:
空闲的线程保留时间,超过这个时间普通线程就会被销毁,保留corepoolsize个线程。
4 TimeUnit:空闲线程保留单位,可以是秒,毫秒,分钟,天,月,年
5 BlokingQueue 阻塞队列:存储等待执行的任务。主要有ArrayBlokingQueue,LinkedBlokingQueue,SynchronousQueue
6 ThreadFactor 线程工厂:用来创建线程。
7 RejectedExecutionHandler:队列已满,超过最大线程数处理策略。
主要有四种策略:
ThreadPoolExecutor.AbortPolicy:丢弃任务并抛出RejectedExecutionException
ThreadPoolExecutor.DiscardPolicy:丢弃任务但不抛出异常。
ThreadPoolExecutor.DiscardOldestPolicy:丢弃最前面的任务,然后重新尝试执行任务。
ThreadPoolExecutor.CallerRunsPolicy:调用线程处理该任务。