Java应用线程池配置例子
一)使用Executors工厂创建线程池
Executors为我们提供默认的执行策略
名称 | 说明 |
newSingleThreadExecutor | 创建一个单线程的线程池。线程池使用无界队列,保证任务顺序执行。 |
newCachedThreadPool | 创建一个线程池。该线程池根据需要创建新的线程,调用execute将重用已构造的线程,如果没有可用的线程,将会创建一个新的线程并加入到线程池中。默认60秒未使用的线程将被终止并从池中删除。 |
newFixedThreadPool(4) | 创建线程数量最大为n的线程池。线程池使用无界队列,如果在所有线程都活跃时提交了任务,则它在队列中等待,直到有一个线程可用。 |
newScheduledThreadPool(4) | 创建一个线程池,该线程池可以安排命令在给定延迟后运行,或定期执行。 |
二)自定义ThreadPoolExecutor
使用ThreadPoolExecutor能够自定义线程池的策略,通用构造函数如下表:
参数 | 类型 | 说明 |
corePoolSize | int | 线程池最小线程数 |
maximumPoolSize | int | 线程池最大线程数 |
keepAliveTime | long | 空闲线程最大等待时间 |
unit | TimeUnit | 空闲线程最大等待时间单位 |
workQueue | BlockingQueue<Runnable> | 任务执行前用于保留任务的队列,比如无界队列,有界队列等待 |
ThreadFactory | threadFactory | 创建新的线程池使用的线程工厂 |
handler | RejectedExecutionHandler | 任务执行,因达到线程最大和队列容量而被阻止时要使用的处理程序 |
保留任务的队列
推荐使用有界队列,避免瞬时任务增加导致资源耗尽。
BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>(100);
饱和策略