Java应用线程池配置例子

Java应用线程池配置例子

一)使用Executors工厂创建线程池

Executors为我们提供默认的执行策略

名称 说明
newSingleThreadExecutor 创建一个单线程的线程池。线程池使用无界队列,保证任务顺序执行。
newCachedThreadPool 创建一个线程池。该线程池根据需要创建新的线程,调用execute将重用已构造的线程,如果没有可用的线程,将会创建一个新的线程并加入到线程池中。默认60秒未使用的线程将被终止并从池中删除。
newFixedThreadPool(4) 创建线程数量最大为n的线程池。线程池使用无界队列,如果在所有线程都活跃时提交了任务,则它在队列中等待,直到有一个线程可用。
newScheduledThreadPool(4) 创建一个线程池,该线程池可以安排命令在给定延迟后运行,或定期执行。

二)自定义ThreadPoolExecutor

使用ThreadPoolExecutor能够自定义线程池的策略,通用构造函数如下表:

参数 类型 说明
corePoolSize int 线程池最小线程数
maximumPoolSize int 线程池最大线程数
keepAliveTime long 空闲线程最大等待时间
unit TimeUnit 空闲线程最大等待时间单位
workQueue BlockingQueue 任务执行前用于保留任务的队列,比如无界队列,有界队列等待
ThreadFactory threadFactory 创建新的线程池使用的线程工厂
handler RejectedExecutionHandler 任务执行,因达到线程最大和队列容量而被阻止时要使用的处理程序

保留任务的队列

推荐使用有界队列,避免瞬时任务增加导致资源耗尽。

BlockingQueue queue = new LinkedBlockingQueue<>(100);

饱和策略

 

你可能感兴趣的:(Java,java,多线程)