总体来说是两个方法:1是通过Executors创建线程池;2是通过ThreadPoolExecutor创建线程池。
具体可分为以下七种方法:
方法 | 含义 |
Executors.newFixedThreadPool | 创建一个大小固定的线程池,可控制并发的线程数,超出的线程会在队列中等待; |
Executors.newCachedThreadPool | 创建一个可缓存的线程池,若线程数超过处理所需,缓存一段时间后会回收,若线程数不够,则新建线程; |
Executors.newSingleThreadExecutors | 创建单个线程数的线程池,它可以保证先进先出的执行顺序; |
Executors.newScheduledThreadPool | 创建一个可以执行延迟任务的线程池; |
Executors.newSingleThreadScheduledExecutor | 创建一个单线程的可以执行延迟任务的线程池 |
Executors.newWorkStealingPool | 创建一个抢占式执行的线程池 |
ThreadPoolExecutor | 最原始的创建线程池的方式,它包含了7个参数可供设置 |
一、Executors.newFixedThreadPool(创建大小固定的线程池)
public class NewFixedThreadPoolDemo {
public static void main(String[] args) throws ExecutionException, InterruptedException {
ExecutorService executorService = Executors.newFixedThreadPool(2);
String submit = executorService.submit(() -> Thread.currentThread().getName()).get();
System.out.println("当前执行的线程名称为:" + submit);
executorService.execute(() -> System.out.println("当前执行的线程名称为:" + Thread.currentThread().getName()));
executorService.execute(() -> System.out.println("当前执行的线程名称为:" + Thread.currentThread().getName()));
executorService.execute(() -> System.out.println("当前执行的线程名称为:" + Thread.currentThread().getName()));
}
}
// 执行结果
当前执行的线程名称为:pool-1-thread-1
当前执行的线程名称为:pool-1-thread-2
当前执行的线程名称为:pool-1-thread-1
当前执行的线程名称为:pool-1-thread-2
结论:创建线程池固定大小为2时,无论开启多少个任务,都只有两个线程执行任务。
二、Executors.newCachedThreadPool(创建一个可缓存的线程池)
public class NewCachedThreadPoolDemo {
public static void main(String[] args) {
ExecutorService executorService = Executors.newCachedThreadPool(); // 2的31次方-1
for (int i = 0; i < 10; i++) {
executorService.execute(new Runnable() {