iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >定时任务实现的关键DelayQueue延迟队列是什么
  • 215
分享到

定时任务实现的关键DelayQueue延迟队列是什么

2023-06-19 11:06:40 215人浏览 独家记忆
摘要

定时任务实现的关键DelayQueue延迟队列是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。今天学习是并发包提供的延迟队列(DelayQueue)。延迟队列说明延迟队

定时任务实现的关键DelayQueue延迟队列是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

今天学习并发包提供的延迟队列(DelayQueue)。

延迟队列说明

延迟队列提供的功能是在指定时间点才能获取队列元素的功能,队列最前面的元素是最优先执行的元素。 

列举一下使用场景可能能够更加好理解,比如缓存系统的设计,缓存中的对象,指定了过期时间,到了过期时间就需要从缓存中移出;在比如任务调度系统,要准确在任务规定的时间点执行任务。这些场景如果我们不使用延迟队列,就必须不同的遍历所有缓存、任务然后判断是否需要移除缓存、执行任务。

而延迟队列则不需要不停的扫描缓存、任务,它能够实现能够实现在准确的时间点去执行任务。 

接下来我们梳理一下缓存准时移除的实现,首先我们知道每个缓存的过期时间,就可以计算出每个缓存过期的时间戳,我们首先根据过期时间戳作为比较放到优先级队列(上一篇文章介绍的优先级队列)中,然后从优先级队列获取缓存,肯定是获取到最先需要过期的缓存,判断缓存是否到了过期时间,如果没到则把线程阻塞(过期时间戳与当前时间戳的差值),一定时间后线程自动唤醒,再次验证发现缓存刚好到期,可以移除缓存。 

同样定时任务的准时执行也一样,只不过是把缓存过期的时间戳换成定时任务下次执行时间戳作为比较依据。 

通过分析发现要实现这个功能需要一个优先级队列,保存的元素要指定移除队列的时间戳

DelayQueue属性介绍

从上一步分析得出延迟队列必须拥有优先级队列的功能,同时保存的元素要有确定移除队列的时间,那么我们来看DelayQueue具体实现,基本属性源码如下图:

 定时任务实现的关键DelayQueue延迟队列是什么

可以看到它利用优先级队列q用来保存数据,那么就拥有了优先级队列的全部功能。

接着看它所能存储的元素都必须继承Delayed,查看Delayed源码发现它继承了Comparable接口,并且声明了方法“long getDelay(TimeUnit unit);”,这个方法的说明翻译过来是:以给定的时间单位返回与此对象关联的剩余延迟。它可以直接得出对象剩余延迟,就像缓存的剩余时间,就可以执行获取到对象的线程阻塞时间。

那么继承至Delayed的对象就同时拥有了优先级队列需要的Comparable的实现和对象剩余延迟执行的时间

DelayQueue关键实现

直接看take方法的实现,源码如下图:

 定时任务实现的关键DelayQueue延迟队列是什么

只要上一篇文章弄懂了优先级队列,在看延迟队列的代码就很简单了。首先利用的是优先级队列获取元素,然后调用getDelay(Delayed接口声明的)方法判断是否阻塞以及阻塞时间

可以看到第一个线程进来了如果发现节点为null则是不限阻塞时间的阻塞,而后面进来的线程如果发现leader不为null也是直接阻塞,后面的线程可以通过leader线程执行完后唤醒,那么leader线程是什么时候唤醒呢? 

leader无限阻塞的原因是队列中没有数据,所以要唤醒肯定就是添加数据的地方,在offer方法保存元素成功后会验证队列最前面的是不是刚刚保存的元素,如果是则会调用available.signal();唤醒线程,代码比较简单就不贴出来了。

延迟队列最佳实践

延迟队列要说最佳实践就要说到前面提交的定时任务了,在之前分析定时任务线程池ScheduledThreadPoolExecutor提到过,所以我们直接来看ScheduledThreadPoolExecutor中的实现,关键源码如下图:

 定时任务实现的关键DelayQueue延迟队列是什么

每个任务在放到任务队列前都会设置下次执行时间time,如上图通过time实现了getDelay和compareTo方法,这样一个线程池就可以保存多个定时任务,每个任务在执行完后会重置time然后继续放到线程池的优先级队列中,就是如此的简单的实现了定时任务。

关于定时任务实现的关键DelayQueue延迟队列是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。

--结束END--

本文标题: 定时任务实现的关键DelayQueue延迟队列是什么

本文链接: https://www.lsjlt.com/news/295733.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 定时任务实现的关键DelayQueue延迟队列是什么
    定时任务实现的关键DelayQueue延迟队列是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。今天学习是并发包提供的延迟队列(DelayQueue)。延迟队列说明延迟队...
    99+
    2023-06-19
  • Redis实现延迟队列的方法是什么
    这篇文章主要介绍“Redis实现延迟队列的方法是什么”,在日常操作中,相信很多人在Redis实现延迟队列的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis实现延迟队列的方法是什么”的疑惑有所...
    99+
    2023-07-05
  • RabbitMQ实现延迟队列的两种方式分别是什么
    这期内容当中小编将会给大家带来有关RabbitMQ实现延迟队列的两种方式分别是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。定时任务各种各样,常见的定时任务例如日志备份,我们可能在每天凌晨 3 点去备...
    99+
    2023-06-22
  • Java定时任务的实现原理是什么
    Java定时任务的实现原理是基于线程池和计时器的机制。在Java中,可以使用ScheduledExecutorService接口来创...
    99+
    2023-10-20
    Java
  • Python定时任务的实现方法是什么
    今天就跟大家聊聊有关Python定时任务的实现方法是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、定时任务定时任务,顾名思义: 定时执行的任务,可以是一段bash命令,也可以...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作