java 多线程ThreadPoolExecutor

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();
        }
   }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值