Executors介绍
Executors是Java中用于创建线程池的工具类,它提供了一组静态方法,可以方便地创建各种类型的线程池。
Executors提供了多种类型的线程池实现,例如FixedThreadPool、CachedThreadPool、ScheduledThreadPool等等,它们各自具有不同的特点和适用场景。
下面是一些常用的Executors方法:
newFixedThreadPool(int nThreads):创建一个固定大小的线程池,线程池中的线程数量固定为nThreads。
newCachedThreadPool():创建一个可缓存的线程池,线程池中的线程数量不固定,可以根据需要自动创建和回收线程。
newSingleThreadExecutor():创建一个单线程的线程池,线程池中只有一个工作线程。
newScheduledThreadPool(int corePoolSize):创建一个固定大小的定时任务线程池,线程池中的线程数量固定为corePoolSize。
Executors还提供了一些其他的方法,例如newWorkStealingPool()、newSingleThreadScheduledExecutor()等等,可以根据具体的需求和场景来选择合适的线程池类型。
Executors示例
下面是一个使用Executors创建线程池的示例代码:
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Main {
public static void main(String[] args) {
ExecutorService executor = Executors.newFixedThreadPool(10);
for (int i = 0; i < 100; i++) {
Runnable task = new MyTask(i);
executor.execute(task);
}
executor.shutdown();
}
private static class MyTask implements Runnable {
private int taskId;
public MyTask(int taskId) {
this.taskId = taskId;
}
@Override
public void run() {
System.out.println("Task " + taskId + " is running on thread " + Thread.currentThread().getName());
}
}
}
在上面的示例代码中,我们使用Executors工厂类创建了一个FixedThreadPool线程池,线程池大小为10。然后,我们提交了100个MyTask任务到线程池中执行,每个任务输出自己的编号和执行的线程名。最后,我们调用shutdown方法关闭线程池。
需要注意的是,在使用Executors创建线程池时,需要根据具体的需求和场景来选择合适的线程池类型和参数配置,以确保线程池的性能和稳定性。同时,我们还需要注意线程池中任务的执行顺序和线程安全问题,以避免出现意外的错误。