Java 中常用的线程池有以下几种:
1. FixedThreadPool(固定大小线程池):
固定大小的线程池,线程数量固定,任务队列为无界队列。适用于任务量可控、并发量不是很大的场景。
2. CachedThreadPool(缓存线程池):
根据需求创建新线程的线程池,适用于短生命周期的异步任务,线程数量不固定,可根据需求动态调整。
3. SingleThreadExecutor(单线程线程池):
只有一个工作线程的线程池,适用于需要保证任务按顺序执行的场景,任务一个一个按顺序执行。
4. ScheduledThreadPool(定时任务线程池):
用于执行定时任务和周期性任务的线程池,可以实现任务的定时执行或者周期性执行。
5. WorkStealingPool(工作窃取线程池):
Java 8 引入的一种线程池,每个线程维护自己的任务队列,可以窃取其他线程队列中的任务,提高了任务执行的并行度和效率。
6. 自定义线程池:
通过 `ThreadPoolExecutor` 类自定义线程池,可以灵活地设置核心线程数、最大线程数、任务队列类型、拒绝策略等参数,适用于特定需求场景。
这些线程池类型都可以在 `java.util.concurrent` 包中找到,并且都实现了 `ExecutorService` 接口。选择合适的线程池类型取决于任务的性质、并发量、以及对性能和资源的需求。