scheduledexecutorservice 只执行一次_ScheduledExecutorService原理分析

本文探讨ScheduledExecutorService的工作原理,通过代码示例展示了如何设置一个只执行一次的任务。分析源码发现,其内部使用延迟队列,并依赖BlockingQueue。scheduleAtFixedRate方法中的delayedExecute是关键,而任务执行状态由AtomicInteger标记。文章提出了关于任务未完成时CPU资源使用的问题,引发思考。
摘要由CSDN通过智能技术生成

最近跟别人聊天,别人问我了一个问题ScheduledExecutorService的原理是啥呢?

说实话,一脸懵逼的就过去了,虽然知道这么个东西,说实话也没细看实现的原理,今天就来分析一下吧。

我们先从一段代码开始今天的旅程。

ScheduledExecutorService scheduledExecutorService = new ScheduledThreadPoolExecutor(1);

这里创建一个线程池为1的调度任务

//1秒后开始启动,每隔3s执行一次service.scheduleAtFixedRate(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName() + "我开始执行了"); }}, 1, 3, TimeUnit.SECONDS);

这里每隔3便会执行一次Runnable。

这便是调度任务服务的简单实用方法,下面来仔细的分析一下源码。

public ScheduledThreadPoolExecutor(int corePoolSize) { super(corePoolSize, Integer.MAX_VALUE, 0, NANOSECONDS, new DelayedWorkQueue());}

进入源码可以看到这里的队列用的是延迟队列的实现。

static class DelayedWorkQueue extends AbstractQueue implements BlockingQueue {
   

通过跟踪源码分析可知,其实底层用的还是BlockingQueue(源码下篇分析),哈哈,看到这里是不是就很清楚了呢?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值