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

相关推荐
老K的Java兵器库7 分钟前
并发集合踩坑现场:ConcurrentHashMap size() 阻塞、HashSet 并发 add 丢数据、Queue 伪共享
java·后端·spring
计算机毕业设计木哥28 分钟前
计算机毕业设计选题推荐:基于SpringBoot和Vue的爱心公益网站
java·开发语言·vue.js·spring boot·后端·课程设计
ANnianStriver30 分钟前
智谱大模型实现文生视频案例
java·aigc
普通网友40 分钟前
KUD#73019
java·php·程序优化
番茄Salad1 小时前
自定义Spring Boot Starter项目并且在其他项目中通过pom引入使用
java·spring boot
程序员三明治1 小时前
详解Redis锁误删、原子性难题及Redisson加锁底层原理、WatchDog续约机制
java·数据库·redis·分布式锁·redisson·watchdog·看门狗
自由的疯1 小时前
Java 怎么学习Kubernetes
java·后端·架构
自由的疯1 小时前
Java kubernetes
java·后端·架构
普通网友2 小时前
IZT#73193
java·php·程序优化
rechol2 小时前
C++ 继承笔记
java·c++·笔记