线程池Executors.newScheduledThreadPool-只执行1次

Posted yaoyuan2

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了线程池Executors.newScheduledThreadPool-只执行1次相关的知识,希望对你有一定的参考价值。

例子1:延迟3秒后,只执行1次

ScheduledExecutorService es = Executors.newScheduledThreadPool(5);
        log.info("开始时间");
        try {
            for (int i = 0; i < 20; i++) {
                Runnable syncRunnable = new Runnable() {
                    @Override
                    public void run() {
                        log.info(Thread.currentThread().getName());
                    }
                };
                es.schedule(syncRunnable, 3000, TimeUnit.MILLISECONDS);
            }
        } finally {
            es.shutdown();
        }

运行结果:

            10:41:39.589 开始时间
            10:41:42.595 pool-1-thread-1
            10:41:42.595 pool-1-thread-2
            10:41:42.595 pool-1-thread-3
            10:41:42.595 pool-1-thread-4
            10:41:42.596 pool-1-thread-2
            10:41:42.596 pool-1-thread-5
            10:41:42.596 pool-1-thread-1
            10:41:42.596 pool-1-thread-3
            10:41:42.597 pool-1-thread-4
            10:41:42.597 pool-1-thread-2
            10:41:42.597 pool-1-thread-5
            10:41:42.597 pool-1-thread-1
            10:41:42.598 pool-1-thread-3
            10:41:42.598 pool-1-thread-4
            10:41:42.598 pool-1-thread-2
            10:41:42.599 pool-1-thread-5
            10:41:42.599 pool-1-thread-1
            10:41:42.600 pool-1-thread-3
            10:41:42.600 pool-1-thread-4
            10:41:42.600 pool-1-thread-2

调用的ThreadPoolExecutor:

public ScheduledThreadPoolExecutor(int corePoolSize) {
        super(corePoolSize, Integer.MAX_VALUE, 0, NANOSECONDS,
              new DelayedWorkQueue());
    }

corePoolSize=5,maximumPoolSize=Integer.MAX_VALUE

keepAliveTime=0纳秒

allowCoreThreadTimeout=false(默认)

采用延迟队列DelayedWorkQueue

因此,

  • 线程池中的线程数永远是5,永久存活
  • 对于新任务,当队列未满时,插入队列;当队列已满时,默认执行AbortPolicy,即抛出异常。
  • 支持线程reuse

因此,类似newFixedThreadPool

 

public ScheduledThreadPoolExecutor(int corePoolSize) {        super(corePoolSize, Integer.MAX_VALUE, 0, NANOSECONDS,              new DelayedWorkQueue());    }

以上是关于线程池Executors.newScheduledThreadPool-只执行1次的主要内容,如果未能解决你的问题,请参考以下文章

什么叫线程池?线程池如何使用?

多线程(六):线程池

多线程(六):线程池

十五、线程池(六)自动创建线程池的弊端

java 如何获得线程池中正在执行的线程数?

线程池参数与线程池调优