Executors 提供了各种类型的线程池,主要有以下工厂方法:
-
public static ExecutorService newFixedThreadPool(int nThreads);
该方法返回一个固定线程数量的线程池。当有新任务提交时,如果线程池中有空闲线程,则立即执行;若没有,则新任务会被暂存在一个任务队列中,带有线程空闲时,变处理在任务队列中的任务。
-
public static ExecutorService newSingleThreadExecutor();
该方法返回一个只有一个线程的线程池。若对于一个任务被提交到该线程池,任务会被保存在一个任务队列中,待线程空闲,按先入先出的顺序执行队列中的任务。
-
public static ExecutorService newCachedThreadPool()
该方法返回一个可根据实际情况调整线程数量的线程池。线程池中的线程数量不确定,但若有空闲线程可以复用,则会优先使用可复用线程;若无可复用线程,则会创建新的线程处理任务。所有线程执行完任务后,将返回线程池进行复用。
-
public static ScheduledExecutorService newSingleThreadScheduledExecutor()
该方法返回一个ScheduledExecutorService的对象,线程池大小为1。扩展了在给定时间执行任务的功能,(如在固定时延后执行,或者周期性执行任务)
-
public static ScheduledExecutorService newScheduledThreadPool(int corePoolSize)
该方法返回一个ScheduledExecutorService对象,但该线程池可以指定线程数量。
1. 固定大小线程池
以newFixedThreadPool()为例,
public static void main(String[] a){ MyTask myTask = new MyTask(); ExecutorService executorService = Executors.newCachedThreadPool(); for (int i = 0; i < 20; i++) { executorService.submit(myTask); } executorService.shutdown(); } 新建一个固定大小为5的线程池,之后将20个任务提交到该线程池, 结果应为:每次调度执行5个任务,分4次执行完提交的20个任务。 |
2. 计划任务
newScheduledThreadPool 返回的ScheduledExecutorService对象,可以根据时间需要对线程进行调度。主要方法如下:
-
public ScheduledFuture<?> schedule(Runnable command, long delay, TimeUnit unit);
该方法会在给定时间,对任务进行一次调度。
-
public ScheduledFuture<?> scheduleAtFixedRate(Runnable command, long initialDelay, long period, TimeUnit unit);
该方法会对任务进行周期性的调度,任务调度的频率是一定的。以上一个任务开始执行时间为起点,之后的period时间,再调度下一次任务。
若任务执行时间大于调度间隔时间,则在任务执行完后,立即执行下一次任务。
(如: 1.任务执行时间为1秒,调度间隔为2秒,则任务按每2秒一次的间隔执行;
2.任务执行时间为5秒,调度间隔为2秒,则任务按每5秒一次执行。)
-
public ScheduledFuture<?> scheduleWithFixedDelay(Runnable command, long initialDelay, long delay, TimeUnit unit);
该方法会对任务进行周期性的调度,任务调度的频率是一定的。以上一个任务执行结束时间为起点,之后的period时间,再调度下一次任务。
(如: 1.任务执行时间为1秒,调度间隔为2秒,则任务按每3秒一次的间隔执行;)