13.线程调度
前言
上一章节我们讲了线程池,那么下面来讲线程池的延时调度执行。
ScheduledExecutorService
代码语言:javascript复制一个 ExecutorService,可安排在给定的延迟后运行或定期执行的命令。
代码示例
代码语言:javascript复制
import java.util.Random;
import java.util.concurrent.*;
/**
*
* 一、线程池:提供了一个线程队列,队列中保存着所有等待状态的线程。避免了创建与销毁额外开销,提高了响应的速度。
*
* 二、线程池的体系结构:
* java.util.concurrent.Executor : 负责线程的使用与调度的根接口
* |--**ExecutorService 子接口: 线程池的主要接口
* |--ThreadPoolExecutor 线程池的实现类
* |--ScheduledExecutorService 子接口:负责线程的调度
* |--ScheduledThreadPoolExecutor :继承 ThreadPoolExecutor, 实现 ScheduledExecutorService
*
* 三、工具类 : Executors
* ExecutorService newFixedThreadPool() : 创建固定大小的线程池
* ExecutorService newCachedThreadPool() : 缓存线程池,线程池的数量不固定,可以根据需求自动的更改数量。
* ExecutorService newSingleThreadExecutor() : 创建单个线程池。线程池中只有一个线程
*
* ScheduledExecutorService newScheduledThreadPool() : 创建固定大小的线程,可以延迟或定时的执行任务。
*
* @author Aron.li
* @date 2020/11/4 21:41
*/
public class TestScheduled {
public static void main(String[] args) throws Exception {
//1.创建调度线程池 ScheduledExecutorService
ScheduledExecutorService pool = Executors.newScheduledThreadPool(5);
//2.使用线程池创建一个线程执行,并且延时调度
Future<Integer> result = pool.schedule(new Callable<Integer>(){
@Override
public Integer call() throws Exception {
int num = new Random().nextInt(100);//生成随机数
System.out.println(Thread.currentThread().getName() " : " num);
return num;
}
}, 1, TimeUnit.SECONDS); // 注意:时间单位是可以根据 TimeUnit.DAYS TimeUnit.DAYS 修改的。
//3.读取结果
System.out.println(result.get());
//4.关闭线程池
pool.shutdown();
}
}
执行效果如下:
image-20201104214808439