一文搞懂 java 线程池:ThreadPoolExecutor 和 FixedThreadPool 原理
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 个简单的任务。每个任务只是简单地打印出一条消息,然后线程池被关闭。
评论已关闭