java线程池有几种
在 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);
这些线程池实现都是通过 `java.util.concurrent.Executors` 类提供的静态方法创建的。除了以上常见的线程池实现,还可以使用 `java.util.concurrent.ThreadPoolExecutor` 类自定义线程池,提供更灵活的配置选项,如核心线程数、最大线程数、等待队列大小、线程工厂、拒绝策略等。
使用线程池可以提高线程的复用性和线程调度的效率,避免了频繁地创建和销毁线程的开销。选择适当的线程池实现取决于具体的需求和场景,需要根据实际情况进行选择。