一文搞懂 java 线程池:ThreadPoolExecutor 和 FixedThreadPool 原理
warning:
这篇文章距离上次修改已过425天,其中的内容可能已经有所变动。
Java 中的 ThreadPoolExecutor 是线程池的核心实现,而 FixedThreadPool 是 ThreadPoolExecutor 的一个常用预定义实现。
ThreadPoolExecutor
ThreadPoolExecutor 的构造方法如下:
public ThreadPoolExecutor(
int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory,
RejectedExecutionHandler handler) {
...
}corePoolSize: 线程池中的常驻核心线程数。maximumPoolSize: 线程池能够容纳的最大线程数。keepAliveTime: 非核心线程的空闲时间,超时自动终止。unit: 空闲时间的单位。workQueue: 任务队列,被提交但未执行的任务。threadFactory: 线程工厂,用于创建线程。handler: 拒绝策略,当任务太多无法处理时的策略。
FixedThreadPool
FixedThreadPool 是 ThreadPoolExecutor 的一个预定义实现,它使用固定的线程数,无界的任务队列 LinkedBlockingQueue,并且使用 Executors.defaultThreadFactory() 和 new ThreadPoolExecutor.CallerRunsPolicy() 作为其线程工厂和拒绝策略。
public static ExecutorService newFixedThreadPool(int nThreads) {
return new ThreadPoolExecutor(
nThreads, nThreads,
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(),
Executors.defaultThreadFactory(),
new ThreadPoolExecutor.CallerRunsPolicy());
}示例代码
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(5);
for (int i = 0; i < 10; i++) {
final int taskId = i;
fixedThreadPool.execute(() -> System.out.println("Executing task " + taskId));
}
fixedThreadPool.shutdown();这段代码创建了一个固定大小的线程池,并执行了 10 个简单的任务。每个任务只是简单地打印出一条消息,然后线程池被关闭。
评论已关闭