package com.ctyun.thread.concurrent; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; /** * @Description TODO * @author zhanghw * @since 2015年12月12日 * @version V1.0 */ public class ThreadPoolDemo { public static void main(String[] args) { /** * 创建一个固定大小的线程池 */ // ExecutorService threadPool = Executors.newFixedThreadPool(3); /** * 创建一个缓存线程池,线程池大小会随着线程任务的多少儿变化。(会自动回收已执行完毕的线程) */ // ExecutorService threadPool = Executors.newCachedThreadPool(); /** * 创建一个只有一个线程的线程池 */ ExecutorService threadPool = Executors.newSingleThreadExecutor(); for (int i = 0; i < 10; i++) { final int taskLoop = i; threadPool.execute(new Runnable() { @Override public void run() { for (int i = 0; i < 10; i++) { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName() + " ,the loop is:" + i + ",the task is" + taskLoop); } } }); } System.out.println("all task has commited!"); /** * 在线程执行完毕之后,程序不会结束,因为线程池中还有三个线程 可以调用threadPool.shutdown()方法,对已经执行完毕的线程进行清理(即杀死所有的线程),并结束任务 */ // threadPool.shutdown();//当所有线程都执行完毕时,清除线程 // threadPool.shutdownNow();//不管线程池中线程中任务是否结束,都清除线程池中所有线程 /** * 创建一个定时任务调度的线程池 */ ScheduledExecutorService threadPool2 = Executors.newScheduledThreadPool(3);
//scheduleAtFixedRate(Runnable command, long initialDelay, long period, TimeUnit unit)
//创建并执行一个在给定初始延迟后首次启用的定期操作,后续操作具有给定的周期;也就是将在 initialDelay 后开始执行,
//然后在 initialDelay+period 后执行,接着在 initialDelay + 2 * period 后执行,依此类推。
//只执行一次的任务 threadPool2.schedule(new Runnable() { @Override public void run() { System.out.println("boning"); } }, 1L, TimeUnit.SECONDS); } }
ScheduledExecutorService#scheduleAtFixedRate() 指的是“以固定的频率”执行,period(周期)指的是两次成功执行之间的时间
比如,scheduleAtFixedRate(command, 5, 2, second)
,第一次开始执行是5s后,假如执行耗时1s,那么下次开始执行是7s后,再下次开始执行是9s后
而ScheduledExecutorService#scheduleWithFixedDelay() 指的是“以固定的延时”执行,delay(延时)指的是一次执行终止和下一次执行开始之间的延迟
scheduleWithFixedDelay(command, 5, 2, second)
,第一次开始执行是5s后,假如执行耗时1s,执行完成时间是6s后,那么下次开始执行是8s后,再下次开始执行是11s后