执行器中延迟运行任务

2024-01-14 04:10
文章标签 运行 任务 延迟 执行器

本文主要是介绍执行器中延迟运行任务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java 9并发编程指南 目录

执行器中延迟运行任务

  • 准备工作
  • 实现过程
  • 工作原理
  • 扩展学习
  • 更多关注

Executor框架提供ThreadPoolExecutor类使用线程池来运行Callable和Runnable任务,以避免所有线程创建操作。当发送任务到执行器时,根据执行器的配置迅速执行。有些实际情况是不需要迅速执行任务的,例如可能在一定时间之后执行或者周期运行任务。为此,执行器框架提供了ScheduledThreadPoolExecutor类实现的ScheduledExecutorService接口。

本节中,讲学习如何创建ScheduledThreadPoolExecutor,并且用来在给定一段时间之后计划任务执行。

准备工作

本范例通过Eclipse开发工具实现。如果使用诸如NetBeans的开发工具,打开并创建一个新的Java项目。

实现过程

通过如下步骤完成范例:

  1. 创建名为Task的类,实现参数为String类的Callable接口:

    public class Task implements Callable<String> {
    
  2. 定义名为name的私有String属性,存储任务名称:

    	private final String name;
    
  3. 实现类构造函数,初始化名称属性:

    	public Task(String name){this.name = name;}
    
  4. 实现call()方法,输出当前时间以及返回一些文本到控制台,例如,你好,世界:

    	@Overridepublic String call() throws Exception {System.out.printf("%s : Starting at : %s\n", name, new Date());return "Hello, world";}
    
  5. 实现范例的主方法,创建一个包含main()方法的Main类:

    public class Main {public static void main(String[] args) {
    
  6. 使用Executors类的newScheduledThreadPool()方法创建ScheduledThreadPoolExecutor类的执行器,传参值1:

    		ScheduledExecutorService executor = Executors.newScheduledThreadPool(1);
    
  7. 使用ScheduledThreadPoolExecutor实例的schedule()方法初始化和启动一些任务(本范例中是五个):

    		System.out.printf("Main : Starting at : %s\n", new Date());for (int i = 0 ; i < 5 ; i ++){Task task = new Task("Task " + i);executor.schedule(task, i+1, TimeUnit.SECONDS);}
    
  8. 使用shutdown()方法请求执行器终止:

    		executor.shutdown();
    
  9. 使用执行器的awaitTermination()方法等待所有任务的终止:

    		try {executor.awaitTermination(1, TimeUnit.DAYS);} catch (InterruptedException e) {e.printStackTrace();}
    
  10. 输出指明程序将要结束的信息到控制台:

    		System.out.printf("Main : Ends at : %s\n", new Date());
    

工作原理

本范例的关键点是Main类和ScheduledThreadPoolExecutor管理。因为使用ThreadPoolExecutor类创建定时执行器,Java要求使用Executors类。本范例中,用到了newScheduledThreadPool()方法,将数字1作为参数传到此方法,这个参数是线程池中线程的数量。

为了一段时间过后,在定时执行器中执行任务,需要使用schedule()方法。此方法接收如下三个参数:

  • 想要执行的任务
  • 在任务执行之前需要等待的时间段
  • 时间段的单位,规定为TimeUnit类的常量

这种情况下,每个任务等待的秒长(TimeUnit.SECONDS)等于其在任务队列中的位置加1。

如果想要在指定时间执行任务,计算此时间与当前时间的差异,作为任务的延迟时间。

下图显示本范例在控制台输出的执行信息:

pics/04_04.jpg

可以看到任务如何每隔一秒开始执行。所有任务在同一时刻传到执行器,但每个任务延迟先前任务1秒执行。

扩展学习

也可以使用Runnable接口实现任务,因为ScheduledThreadPoolExecutor类的schedule()方法允许这两种任务类型:

虽然ScheduledThreadPoolExecutor类是ThreadPoolExecutor类的子类(所以继承其所有特性),但Java要求只对定时任务使用ScheduledThreadPoolExecutor。

最后,当调用shutdown()方法,且有等待延迟时间结束的待定线程时,则可以配置ScheduledThreadPoolExecutor类的特性。默认特性是这些线程将被执行,而不考虑执行器终止。通过使用ScheduledThreadPoolExecutor类的setExecuteExistingDelayedTasksAfterShutdownPolicy()方法改变这个特性。如果调用setExecuteExistingDelayedTasksAfterShutdownPolicy()方法传参false值,待定线程在调用shutdown()方法后不会被执行。

更多关注

本章“执行器中运行返回结果的任务”小节。

这篇关于执行器中延迟运行任务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/603898

相关文章

通过prometheus监控Tomcat运行状态的操作流程

《通过prometheus监控Tomcat运行状态的操作流程》文章介绍了如何安装和配置Tomcat,并使用Prometheus和TomcatExporter来监控Tomcat的运行状态,文章详细讲解了... 目录Tomcat安装配置以及prometheus监控Tomcat一. 安装并配置tomcat1、安装

Spring Boot 整合 ShedLock 处理定时任务重复执行的问题小结

《SpringBoot整合ShedLock处理定时任务重复执行的问题小结》ShedLock是解决分布式系统中定时任务重复执行问题的Java库,通过在数据库中加锁,确保只有一个节点在指定时间执行... 目录前言什么是 ShedLock?ShedLock 的工作原理:定时任务重复执行China编程的问题使用 Shed

mysqld_multi在Linux服务器上运行多个MySQL实例

《mysqld_multi在Linux服务器上运行多个MySQL实例》在Linux系统上使用mysqld_multi来启动和管理多个MySQL实例是一种常见的做法,这种方式允许你在同一台机器上运行多个... 目录1. 安装mysql2. 配置文件示例配置文件3. 创建数据目录4. 启动和管理实例启动所有实例

IDEA运行spring项目时,控制台未出现的解决方案

《IDEA运行spring项目时,控制台未出现的解决方案》文章总结了在使用IDEA运行代码时,控制台未出现的问题和解决方案,问题可能是由于点击图标或重启IDEA后控制台仍未显示,解决方案提供了解决方法... 目录问题分析解决方案总结问题js使用IDEA,点击运行按钮,运行结束,但控制台未出现http://

解决Spring运行时报错:Consider defining a bean of type ‘xxx.xxx.xxx.Xxx‘ in your configuration

《解决Spring运行时报错:Considerdefiningabeanoftype‘xxx.xxx.xxx.Xxx‘inyourconfiguration》该文章主要讲述了在使用S... 目录问题分析解决方案总结问题Description:Parameter 0 of constructor in x

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

Python Invoke自动化任务库的使用

《PythonInvoke自动化任务库的使用》Invoke是一个强大的Python库,用于编写自动化脚本,本文就来介绍一下PythonInvoke自动化任务库的使用,具有一定的参考价值,感兴趣的可以... 目录什么是 Invoke?如何安装 Invoke?Invoke 基础1. 运行测试2. 构建文档3.

解决Cron定时任务中Pytest脚本无法发送邮件的问题

《解决Cron定时任务中Pytest脚本无法发送邮件的问题》文章探讨解决在Cron定时任务中运行Pytest脚本时邮件发送失败的问题,先优化环境变量,再检查Pytest邮件配置,接着配置文件确保SMT... 目录引言1. 环境变量优化:确保Cron任务可以正确执行解决方案:1.1. 创建一个脚本1.2. 修

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五