线程池创建
- 方式一:通过new ThreadPoolExecutor创建线程;ThreadPoolExecutor有7个参数;
分别为
corePoolSize核心线程数;
maximumPoolSize最大线程数;
keepAliveTime非核心线程闲置回收时间;
unit时间单位;workQueue核心线程数满了之后,进入排队的线程队列;
threadFactory线程工厂(一般使用默认线程工厂Executors.defaultThreadFactory())
RejectedExecutionHandler拒绝策略;有如下拒绝策略:
AbortPolicy 在线程池满了之后抛出异常;
CallerRunsPolicy在线程池满了后将线程退回到调用线程池的线程
DiscardOldestPolicy在线程池满了后丢弃等待时间最久的线程
DiscardPolicy在线程池满了后之间丢弃新进线程
创建线程池代码示例:
//创建一个核心线程数为2,最大线程数为6,非核心线程闲置6秒后进行回收,排队等待阻塞队列长度为3的线程池
ExecutorService executorService = new ThreadPoolExecutor(2,6,1L, TimeUnit.SECONDS,new LinkedBlockingQueue<>(3), Executors.defaultThreadFactory(),new ThreadPoolExecutor.AbortPolicy());
- 方式二:通过Executors创建线程池
//创建可自动扩容的线程池
Executors.newCachedThreadPool();
//创建一个固定大小的线程池,参数为线程池大小
Executors.newFixedThreadPool(3);
//创建一个大小为1的线程池
Executors.newSingleThreadExecutor();
线程池调用
通过execute传入runnable即可调用
for (int i = 0; i < 3; i++) {
executorService.execute(()->{
System.out.println("你好");
});
线程池执行方式
1:若新线程进入到线程池,核心线程数未满,则执行该线程
2.若新线程进入到线程池,核心线程数已满,则线程加入到阻塞队列
3 若新线程进入到线程,阻塞队列已满,线程池运行的线程未到最大线程数,则之间运行新加入的线程
4 若新线程进入到线程,线程池达到最大线程数,则执行拒绝策略