在 Java 中,有以下几种常见的线程池类型:
1. FixedThreadPool(固定大小线程池):该线程池维护固定数量的线程,在执行任务时不会创建新的线程。如果所有线程都处于活动状态,新的任务会在等待队列中等待。
示例代码:
ExecutorService executor = Executors.newFixedThreadPool(5);
2. CachedThreadPool(缓存线程池):该线程池的线程数量是没有限制的,它会根据需要创建新的线程。如果有空闲线程可用,会重用空闲线程;如果没有可用的空闲线程,则创建新的线程。
示例代码:
ExecutorService executor = Executors.newCachedThreadPool();
3. SingleThreadExecutor(单线程线程池):该线程池只有一个线程,用于按顺序执行提交的任务。如果该线程意外终止,会创建一个新的线程来替代它。适用于需要保证顺序执行任务的场景。
示例代码:
ExecutorService executor = Executors.newSingleThreadExecutor();
4. ScheduledThreadPool(定时任务线程池):该线程池用于执行定时任务和周期性任务。可以指定线程数量,可以调度任务在固定的延迟或周期执行。
示例代码:
ScheduledExecutorService executor = Executors.newScheduledThreadPool(3);
除了以上常见的线程池类型,还可以使用 ThreadPoolExecutor 类自定义线程池。ThreadPoolExecutor 提供了更灵活的配置选项,如核心线程数、最大线程数、等待队列大小、线程工厂、拒绝策略等。
示例代码:
ThreadPoolExecutor executor = new ThreadPoolExecutor(
corePoolSize,
maximumPoolSize,
keepAliveTime,
TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(),
threadFactory,
rejectedExecutionHandler
);
这些线程池类型提供了不同的线程管理策略和资源配置,可以根据具体的需求选择适合的线程池类型。使用线程池可以提高线程的复用性和线程调度的效率,避免了频繁地创建和销毁线程的开销。