ScheduledFuture定时任务

本文介绍了Java并发包中的ScheduledExecutorService,如何安排任务执行、定时与周期性任务、灵活的调度、线程池管理、异常处理及任务取消功能。
摘要由CSDN通过智能技术生成
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 对象,你可以取消任务的执行,或者查询任务的状态(是否完成、是否取消等)。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot中,可以使用`@EnableScheduling`注解启用定时任务功能,并使用`@Scheduled`注解来定义定时任务的执行规则。然而,这种方式在编译时就已经确定了定时任务的执行时间,无法实现动态创建和管理定时任务的需求。 要实现动态创建定时任务,可以借助`TaskScheduler`接口和`CronTrigger`类。下面是一个简单的示例: 首先,创建一个接口 `TaskSchedulerService`,定义动态创建和删除定时任务的方法: ```java public interface TaskSchedulerService { void scheduleTask(String taskName, Runnable task, String cronExpression); void cancelTask(String taskName); } ``` 然后,创建一个实现类 `TaskSchedulerServiceImpl`,实现上述接口: ```java @Component public class TaskSchedulerServiceImpl implements TaskSchedulerService { @Autowired private ThreadPoolTaskScheduler taskScheduler; private Map<String, ScheduledFuture<?>> scheduledTasks = new ConcurrentHashMap<>(); @Override public void scheduleTask(String taskName, Runnable task, String cronExpression) { ScheduledFuture<?> scheduledTask = taskScheduler.schedule(task, new CronTrigger(cronExpression)); scheduledTasks.put(taskName, scheduledTask); } @Override public void cancelTask(String taskName) { ScheduledFuture<?> scheduledTask = scheduledTasks.get(taskName); if (scheduledTask != null) { scheduledTask.cancel(true); scheduledTasks.remove(taskName); } } } ``` 在上述实现类中,我们使用了`ThreadPoolTaskScheduler`来执行定时任务,并通过`Map`来保存已经创建的定时任务。 最后,在需要动态创建定时任务的地方,注入`TaskSchedulerService`,调用相应的方法即可: ```java @Autowired private TaskSchedulerService taskSchedulerService; public void createTask() { taskSchedulerService.scheduleTask("task1", () -> { // 定时任务逻辑 System.out.println("Task 1 executed!"); }, "0 * * * * *"); // 每分钟执行一次 } public void cancelTask() { taskSchedulerService.cancelTask("task1"); } ``` 通过上述方式,你可以动态创建和删除定时任务,并根据需要指定不同的执行时间。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值