执行器中延迟运行任务

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

相关文章

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

跨系统环境下LabVIEW程序稳定运行

在LabVIEW开发中,不同电脑的配置和操作系统(如Win11与Win7)可能对程序的稳定运行产生影响。为了确保程序在不同平台上都能正常且稳定运行,需要从兼容性、驱动、以及性能优化等多个方面入手。本文将详细介绍如何在不同系统环境下,使LabVIEW开发的程序保持稳定运行的有效策略。 LabVIEW版本兼容性 LabVIEW各版本对不同操作系统的支持存在差异。因此,在开发程序时,尽量使用

如何在运行时修改serialVersionUID

优质博文:IT-BLOG-CN 问题 我正在使用第三方库连接到外部系统,一切运行正常,但突然出现序列化错误 java.io.InvalidClassException: com.essbase.api.base.EssException; local class incompatible: stream classdesc serialVersionUID = 90314637791991

ActiveMQ—消息特性(延迟和定时消息投递)

ActiveMQ消息特性:延迟和定时消息投递(Delay and Schedule Message Delivery) 转自:http://blog.csdn.net/kimmking/article/details/8443872 有时候我们不希望消息马上被broker投递出去,而是想要消息60秒以后发给消费者,或者我们想让消息没隔一定时间投递一次,一共投递指定的次数。。。 类似

FreeRTOS学习笔记(二)任务基础篇

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、 任务的基本内容1.1 任务的基本特点1.2 任务的状态1.3 任务控制块——任务的“身份证” 二、 任务的实现2.1 定义任务函数2.2 创建任务2.3 启动任务调度器2.4 任务的运行与切换2.4.1 利用延时函数2.4.2 利用中断 2.5 任务的通信与同步2.6 任务的删除2.7 任务的通知2

MySQL主从同步延迟原理及解决方案

概述 MySQL的主从同步是一个很成熟的架构,优点为: ①在从服务器可以执行查询工作(即我们常说的读功能),降低主服务器压力; ②在从主服务器进行备份,避免备份期间影响主服务器服务; ③当主服务器出现问题时,可以切换到从服务器。 相信大家对于这些好处已经非常了解了,在项目的部署中也采用这种方案。但是MySQL的主从同步一直有从库延迟的问题,那么为什么会有这种问题。这种问题如何解决呢? MyS

Flink任务重启策略

概述 Flink支持不同的重启策略,以在故障发生时控制作业如何重启集群在启动时会伴随一个默认的重启策略,在没有定义具体重启策略时会使用该默认策略。如果在工作提交时指定了一个重启策略,该策略会覆盖集群的默认策略默认的重启策略可以通过 Flink 的配置文件 flink-conf.yaml 指定。配置参数 restart-strategy 定义了哪个策略被使用。常用的重启策略: 固定间隔 (Fixe

第49课 Scratch入门篇:骇客任务背景特效

骇客任务背景特效 故事背景:   骇客帝国特色背景在黑色中慢慢滚动着! 程序原理:  1 、 角色的设计技巧  2 、克隆体的应用及特效的使用 开始编程   1、使用 黑色的背景: ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/7d74c872f06b4d9fbc88aecee634b074.png#pic_center)   2

win7+ii7+tomcat7运行javaWeb开发的程序

转载请注明出处:陈科肇 1.前提准备: 操作系统:windows 7 旗舰版   x64 JDK:jdk1.7.0_79_x64(安装目录:D:\JAVA\jdk1.7.0_79_x64) tomcat:32-bit64-bit Windows Service Installer(安装目录:D:\0tomcat7SerV) tomcat-connectors:tomcat-connect

php 7之PhpStorm + Nginx + Xdebug运行调试

操作环境: windows PHP 7.1.10 PhpStorm-2017.2.4 Xdebug 2.5.4 Xdebug helper 1.6.1 nginx-1.12.2 注意查看端口占用情况 netstat -ano //查看所以端口netstat -aon|findstr "80" //查看指定端口占用情况 比如80端口查询情况 TCP 0.0.0.0:8