public static void main(String[] args) {
ScheduledExecutorService executor = Executors.newScheduledThreadPool(1);
// 取消之前的任务(如果存在)Callable可以获取任务执行的返回值
Callable<String> task1 = () -> {return "Task executed at: " + System.currentTimeMillis();};
// 安排任务在10秒后执行
ScheduledFuture<?> future = executor.schedule(task1, 10, TimeUnit.SECONDS);
try {
// 等待任务执行完成
System.out.println(future.get());
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
} finally {
// 关闭执行器服务
executor.shutdown();
}
}
ScheduledExecutorService 是 Java 并发包 java.util.concurrent 中的一个接口,它主要用于安排命令在给定的延迟后运行,或者定期地执行命令。这个接口提供了一种灵活的方式来处理定时任务和周期性任务。
ScheduledExecutorService 的主要作用包括:
定时执行任务:你可以安排一个任务在未来的某个时间点执行。这对于那些需要在特定时间后运行的任务非常有用,比如定时发送通知、定时检查系统状态等。
周期性执行任务:你可以安排一个任务按照固定的频率重复执行。这对于那些需要定期执行的任务来说非常有用,比如定时清理缓存、周期性地检查文件系统的变化等。
灵活的任务调度:ScheduledExecutorService 提供了多种调度方法,允许你指定任务的初始延迟、执行间隔以及执行次数等。这使得你可以根据具体需求来定制任务的调度策略。
线程池管理:ScheduledExecutorService 内部通常维护一个线程池来管理任务的执行。这意味着你可以提交多个任务给 ScheduledExecutorService,它会利用线程池来高效地并发执行这些任务。
异常处理:如果任务在执行过程中抛出异常,ScheduledExecutorService 会捕获这些异常,并可以根据需要进行处理或记录。这有助于确保整个系统的稳定性和可靠性。
任务取消和查询:通过返回的 ScheduledFuture 对象,你可以取消任务的执行,或者查询任务的状态(是否完成、是否取消等)。