ExecutorDemo1.java import java.util.concurrent.*;public class ExecutorDemo1 { public static void main(String[] args) { Executor executor = null; // 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等
import java.util.concurrent.*;
public class ExecutorDemo1 {
public static void main(String[] args) {
Executor executor = null;
// 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待
executor = Executors.newFixedThreadPool(10);
// 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程
executor = Executors.newCachedThreadPool();
// 创建一个定长线程池,支持定时及周期性任务执行
executor = Executors.newScheduledThreadPool(10);
// 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行
executor = Executors.newSingleThreadExecutor();
Runnable task = new Runnable() {
@Override
public void run() {
System.out.println("task over:" + Thread.currentThread().getId());
}
};
// executor.execute(task);
// 周期性任务执行线程
executor = Executors.newScheduledThreadPool(10);
ScheduledExecutorService scheduler = (ScheduledExecutorService) executor;
scheduler.scheduleAtFixedRate(task, 5, 1, TimeUnit.SECONDS);
}
}
