当前位置: 首页 > news >正文

java中的ScheduledExecutorService介绍和使用案例

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

主要特点

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

使用案例

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

http://www.lryc.cn/news/467528.html

相关文章:

  • 4天涨粉14万!这个AI小众赛道粉丝涨疯了吧?保姆级教程免费教会你!
  • RK3588 技术分享 | 在Android系统中使用NPU实现Yolov5分类检测
  • itext 转换word文档转pdf
  • WSL-默认root登录
  • ASIO网络调试助手之四:浅谈QTcpServer性能
  • 快手 日常实习一面面经
  • Cursor零基础小白教程系列 - 创建你的第一个Cursor 项目
  • 通用序列化和反序列化实现思路
  • 书生营第四期L0G2000 Python 基础知识
  • Day12-数据库服务冗余架构
  • js监听div尺寸,ResizeObserver
  • STM32与openmv的串口通信
  • C#基于SkiaSharp实现印章管理(11)
  • Spring使用@Async出现循环依赖原因以及解决方案
  • 如何训练 RAG 模型
  • 鸿蒙网络编程系列34-Wifi热点扫描及连接示例
  • LVS三种模式工作原理
  • 【二轮征稿启动】第三届环境工程与可持续能源国际会议持续收录优质稿件
  • 网络安全——防火墙技术
  • Missing classes detected while running R8报错解决方案
  • 智能指针
  • 通过DevTools逃离Chrome沙盒(CVE-2024-6778和CVE-2024-5836)
  • 手持无人机飞手执照,会组装调试入伍当兵有多香!
  • 项目经理好累好烦啊,不想干了....
  • 论技术人员“技术人格”的重要意义
  • Kafka异常重试方案小记
  • 非页面缓冲池占用过高处理方法
  • 【Linux】进程信号(下)
  • FlinkCDC 实现 MySQL 数据变更实时同步
  • JavaWeb——Maven(4/8):Maven坐标,idea集成-导入maven项目(两种方式)