谈谈你对 ThreadPoolExecutor 类的理解。
ThreadPoolExecutor是Java并发库中提供的一个类,它是ExecutorService接口的实现类。ThreadPoolExecutor提供了线程池的实现,可以创建一个可重用的线程池,这对于需要大量并发线程的应用程序来说是非常有用的。
ThreadPoolExecutor的主要参数包括:
- corePoolSize:线程池的基本大小,即在没有任务需要执行的时候线程池的大小,并且只有在工作队列满了的情况下才会创建超出这个数量的线程。
- maximumPoolSize:线程池最大线程数,这个参数也就是线程池能够容纳的最大线程数,它包括了队列中等待的任务,也包括正在执行的任务。
- keepAliveTime:线程空闲时的存活时间,即超过corePoolSize的空闲线程在多长时间内会被销毁。
- unit:keepAliveTime的时间单位。
- workQueue:线程池所使用的阻塞队列,用来存储待执行的任务,一般来说这个阻塞队列有以下几种选择:ArrayBlockingQueue、LinkedBlockingQueue、SynchronousQueue。
- threadFactory:线程工厂,主要用来创建线程。
- handler:表示当拒绝处理任务时的策略,有以下四种取值:ThreadPoolExecutor.AbortPolicy、ThreadPoolExecutor.CallerRunsPolicy、ThreadPoolExecutor.DiscardOldestPolicy、ThreadPoolExecutor.DiscardPolicy。
举个例子,以下是创建一个线程池的代码:
ThreadPoolExecutor executor = new ThreadPoolExecutor(5, 10, 200,
TimeUnit.MILLISECONDS, new ArrayBlockingQueue<Runnable>(5));
这个线程池的核心线程数为5,最大线程数为10,如果线程池中的线程数量超过5,那么多余的线程在空闲时间超过200毫秒后会被销毁。同时,这个线程池使用一个能够容纳5个任务的ArrayBlockingQueue作为它的工作队列。