java中的ScheduledExecutorService介绍和使用案例

ScheduledExecutorService 是 Java 并发包 java.util.concurrent 中的一个接口,它提供了一种机制,允许我们安排一个任务在给定的延迟后运行,或者定期地执行。

主要特点

  1. 单次调度:可以安排任务在一定的延迟后执行一次。
  2. 周期性调度:可以安排任务按照一定的周期重复执行。
  3. 线程池ScheduledExecutorService 实现了 ExecutorService 接口,因此它拥有线程池的特性,可以复用线程,提高效率。
  4. 灵活的调度策略:可以灵活地控制任务的执行时间。

使用案例

1. 单次调度
java 复制代码
import java.util.concurrent.*;

public class SingleScheduleExample {
    public static void main(String[] args) {
        ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);

        scheduler.schedule(() -> {
            System.out.println("任务执行了");
        }, 5, TimeUnit.SECONDS); // 5秒后执行

        scheduler.shutdown();
    }
}
2. 周期性调度
java 复制代码
import java.util.concurrent.*;

public class PeriodicScheduleExample {
    public static void main(String[] args) {
        ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);

        Runnable task = () -> {
            System.out.println("周期性任务执行了");
        };

        scheduler.scheduleAtFixedRate(task, 1, 3, TimeUnit.SECONDS); // 初始延迟1秒,之后每3秒执行一次

        // 如果需要在一定次数后停止
        scheduler.schedule(() -> scheduler.shutdown(), 10, TimeUnit.SECONDS);
    }
}
3. 固定延迟调度
java 复制代码
import java.util.concurrent.*;

public class FixedDelayScheduleExample {
    public static void main(String[] args) {
        ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);

        Runnable task = () -> {
            System.out.println("固定延迟任务执行了");
        };

        scheduler.scheduleWithFixedDelay(task, 1, 3, TimeUnit.SECONDS); // 初始延迟1秒,之后每次执行完任务后等待3秒再执行下一次

        // 如果需要在一定次数后停止
        scheduler.schedule(() -> scheduler.shutdown(), 10, TimeUnit.SECONDS);
    }
}

注意事项

  1. 资源管理 :使用 ScheduledExecutorService 时,需要正确管理资源,比如在不再需要时调用 shutdown()shutdownNow() 方法来关闭线程池。
  2. 异常处理:任务中抛出的异常不会影响其他任务的执行,但是如果不处理,可能会导致任务终止。
  3. 线程安全 :提交给 ScheduledExecutorService 的任务应该是线程安全的,或者在任务内部正确处理同步。

ScheduledExecutorService 是一个非常强大的工具,可以帮助我们处理需要定时或周期性执行的任务,而且它还提供了线程池的优化,使得资源利用更加高效。

相关推荐
爱笑的眼睛111 小时前
PyTorch Lightning:重新定义深度学习工程实践
java·人工智能·python·ai
Kevinyu_1 小时前
责任链模式
java·hadoop·责任链模式
明洞日记1 小时前
【设计模式手册012】责任链模式 - 请求处理的流水线艺术
java·设计模式·责任链模式
q***07141 小时前
Java实战:Spring Boot application.yml配置文件详解
java·网络·spring boot
雨中飘荡的记忆2 小时前
Spring Alibaba AI 实战指南
java·ai编程
冰封剑心2 小时前
MiniCPM-V-2_6 (4-bit 量化)使用
java·前端·数据库
mqiqe2 小时前
【Spring AI MCP】四、MCP 服务端
java·人工智能·spring
l***74942 小时前
springboot与springcloud对应版本
java·spring boot·spring cloud
稚辉君.MCA_P8_Java2 小时前
Gemini永久会员 Java实现的暴力递归版本
java·数据结构·算法
许商2 小时前
【stm32】【printf】
java·前端·stm32