java 多线程ThreadPoolExecutor
ThreadPoolExecutor 参数
public ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory,
RejectedExecutionHandler handler)
1.corePoolSize:核心线程池的大小。当提交一个任务到线程池时,核心线程池会创建一个核心线程来 执行任务,即使其他核心线程能够执行新任务也会创建线程,等到需要执行的任务数大于核心线程池基本大小时就不再创建。如果调用了线程池的 prestartAllCoreThreads() 方法,核心线程池会提前创建并启动所有核心线程。
2.maximumPoolSize:线程池允许创建的最大线程数。如果队列也满了,并且已创建的线程数小于最大线程数,则线程池会再创建新的空闲线程执行任务。值得注意的是,如果使用了无界的任务队列则这个参数不起作用。
3.keepAliveTime:当线程池中的线程数大于 corePoolSize 时,keepAliveTime 为多余的空闲线程等待新任务的最长时间,超过这个时间后多余的线程将被终止。所以,如果任务很多,并且每个任务执行的时间比较短,可以调大时间,提高线程的利用率。值得注意的是,如果使用了无界的任务队列则这个参数不起作用。
4.unit:线程活动保持时间的单位。
5.workQueue:任务队列。当核心线程池中没有线程时,所提交的任务会被暂存在队列中。
6.threadFactory:创建线程的工厂。
7.handler:饱和策略。当队列和线程池都满了,说明线程池处于饱和状态,那么必须采取一种策略处理 提交的新任务。
Java 提供了以下4种策略:
AbortPolicy:默认。直接抛出异常。
CallerRunsPolicy:只用调用者所在线程来运行任务。
DiscardOldestPolicy:丢弃队列里最近的一个任务,并执行当前任务。
DiscardPolicy:不处理,丢弃掉。
public void jDataTask() {
ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("jk-pool-%d").build();
ExecutorService executorService = new ThreadPoolExecutor(10,
20,
0L,
TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<>(1024),
namedThreadFactory,
new ThreadPoolExecutor.AbortPolicy());
try {
Product produc = new Product ();
produc .setStatus(1);
produc .setLimit(500);
List<Product> list = productService.queryAll(Product );
if (null != list && list.size() > 0) {
for (Productc product: list) {
executorService.execute(() -> {
try {
productManager.baseCredit(product.getCustomerId());
} catch (Exception e) {
e.printStackTrace();
}
});
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
executorService.shutdown();
}
}