定时器线程池(ScheduledThreadPoolExecutor)

本文介绍了ScheduledThreadPoolExecutor,它是Java中的定时器线程池,能实现任务的延迟和周期性执行。ScheduledThreadPoolExecutor基于ThreadPoolExecutor,使用DelayedWorkQueue作为任务队列,ScheduledFutureTask作为任务实现。重点讨论了DelayedWorkQueue、RunnableScheduledFuture接口以及构造函数中的time和period参数在任务执行中的作用。最后,强调了任务执行的注意事项,如任务等待时间、周期执行条件和异常处理的重要性。
摘要由CSDN通过智能技术生成

前言
定时器线程池提供了定时执行任务的能力,即可以延迟执行,可以周期性执行。但定时器线程池也还是线程池,最底层实现还是ThreadPoolExecutor,可以参考我的另外一篇文章多线程–精通ThreadPoolExecutor。

特点说明

1.构造函数

 public ScheduledThreadPoolExecutor(int corePoolSize) {
   
 // 对于其他几个参数在ThreadPoolExecutor中都已经详细分析过了,所以这里,将不再展开
 // 这里我们可以看到调用基类中的方法时有个特殊的入参DelayedWorkQueue。
 // 同时我们也可以发现这里并没有设置延迟时间、周期等参数入口。
 // 所以定时执行的实现必然在DelayedWorkQueue这个对象中了。
        super(corePoolSize, Integer.MAX_VALUE, 0, NANOSECONDS,
              new DelayedWorkQueue());
    }

2.DelayedWorkQueue
DelayedWorkQueue是在ScheduledThreadPoolExecutor的一个内部类,实现了BlockingQueue接口
里面存放任务队列的数组如下:

private RunnableScheduledFuture<?>[] queue =
            new RunnableScheduledFuture<?>[INITIAL_CAPACITY];

我们分析过ThreadPoolExecutor,它从任务队列中获取任务的方式为poll和take两种,所以看一下poll和take两个方法的源码,回顾一下,ThreadPoolExecutor它会调用poll或take方法,先poll,再take,只要其中一个接口有返回就行

public RunnableScheduledFuture<?> poll() {
   
            final ReentrantLock lock = this.lock;
            lock.lock();
            try {
   
                RunnableScheduledFuture<?> first = queue
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值