DelayedWorkQueue与ScheduledFutureTask

本文介绍了ScheduledThreadPoolExecutor中使用的DelayedWorkQueue,它是一个实现了BlockingQueue接口的内部类,允许存储Delayed元素。DelayedWorkQueue在队列满时会自动扩容,而不同于其他固定容量的BlockingQueue。同时,文章详细讲解了ScheduledFutureTask,它是RunnableScheduledFuture接口的实现类,用于创建队列中实际存储的任务实例。ScheduledFutureTask包含时间属性time,用于设定任务执行的延迟时间。
摘要由CSDN通过智能技术生成

关键词:BlockingQueue    DelayedWorkQueue    ScheduledFutureTask    ScheduledThreadPoolExecutor

 在ScheduledThreadPoolExecutor这种类型的ThreadPoolExecutor线程池中,使用到的阻塞队列为DelayedWorkQueue,并且需要了解ScheduledFutureTask。为方便ScheduledThreadPoolExecutor的学习,这里先介绍DelayedWorkQueue、ScheduledFutureTask。


█ DelayedWorkQueue

DelayedWorkQueue实现了BlockingQueue接口,其是在ScheduledThreadPoolExecutor中定义的一个内部类。

static class DelayedWorkQueue extends AbstractQueue<Runnable>
    implements BlockingQueue<Runnable>

从DelayedWorkQueue的类定义上面可以看出,泛型为Runnable,即DelayedWorkQueue队列中存放的元素类型为Runnable类型。

字段:

private static final int INITIAL_CAPACITY = 16;
private RunnableScheduledFuture<?>[] queue =
    new RunnableScheduledFuture<?>[INITIAL_CAPACITY];
private final ReentrantLock lock = new ReentrantLock();
private int size = 0;
private Thread leader = null;
private final Condition available = lock.newCondition();
  • queue

RunnableScheduledFuture类型的数组,从DelayedWorkQueue类的定义上已经看见,其声明的泛型类型为Runnable类型,实际上队列中存放的具体类型为RunnableScheduledFuture。

public interface RunnableScheduledFuture<V> extends RunnableFuture<V>, ScheduledFuture<V> {

    boolean isPeriodic();
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值