1、ThreadPoolExecutor简介

ThreadPoolExecutor是Java提供的一个线程池类,它提供了一种可以控制线程数量,复用空闲线程,管理线程生命周期的机制。它可以让开发者将线程管理和线程池管理代码从业务逻辑代码中分离出来,从而提高程序的健壮性和可维护性。

2、ThreadPoolExecutor的优点

ThreadPoolExecutor的优点有:

1)可以根据需要调整线程池中线程的数量,使得系统更加灵活,可以根据系统的负载情况动态调整线程池的大小;

2)可以复用空闲线程,减少线程的创建和销毁,从而减少系统开销;

3)可以限制线程池中线程的最大数量,防止系统因线程过多而出现问题;

4)可以对线程进行统一的管理,可以实现统一的线程池管理、线程优先级管理、线程池容量控制等功能;

3、ThreadPoolExecutor的使用

ThreadPoolExecutor的使用非常简单,只需要创建一个ThreadPoolExecutor对象,然后调用它的execute()方法来执行任务即可,例如:

ThreadPoolExecutor executor = new ThreadPoolExecutor(5, 10, 200, TimeUnit.MILLISECONDS, new ArrayBlockingQueue<Runnable>(5));
for(int i=0;i<15;i++){
MyTask myTask = new MyTask(i);
executor.execute(myTask);
System.out.println("线程池中线程数目:"+executor.getPoolSize()+",队列中等待执行的任务数目:"+
executor.getQueue().size()+",已执行玩别的任务数目:"+executor.getCompletedTaskCount());
}
executor.shutdown();

上面的代码创建了一个ThreadPoolExecutor线程池,线程池的初始线程数为5,最大线程数为10,线程池的空闲线程存活时间为200毫秒,线程池中等待队列的长度为5,然后循环提交15个任务给线程池,最后调用shutdown()方法关闭线程池。