线程池延时类ScheduledExecutorService—比Timer更有效精确的延时工具

ScheduledExecutorService

前言

  在Java中我们一般使用Timer来进行延时/周期执行操作,Timer的内部只有一个线程,如果有多个任务的话就会顺序执行,这样我们的延迟时间和循环时间就会出现问题。除此之外:在多线程并发执行定时操作时,Timer运行多个TimerTask,如果其中一个任务没有异常没有捕获,那所有任务都将终止。还有就是,Timer是基于绝对时间,而ScheduledExecutorService是基于相对时间的,这个看情况而定,一般基于相对时间更灵活一些。所以作为Timer的替代品,在对延迟任务和循环任务要求严格的时候,最好使用ScheduledExecutorService。
ScheduledExecutorService提供了三种方法来进行延时/周期操作:schedule、scheduleAtFixedRate、scheduleWithFixedDelay。

schedule方法

ScheduledExecutorService用于延迟一段时间后执行任务或者周期性的执行任务.通常使用Executor类的工厂方法去实例化一个ScheduledExecutorService是一个比较好的方式。.

 ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(1000);
//延迟两秒打印fsd,这里使用了lamda表达式简化,相当于new Runable()
 scheduledThreadPool.schedule(() ->System.out.println("fsd"), 2, TimeUnit.SECONDS);

scheduleAtFixedRate方法

scheduleAtFixedRate()方法在延迟一段时间之后周期性的执行一个任务.下面的代码将会先延迟1秒之后首次执行,之后每隔3秒执行,不管任务耗时多久,3秒后都立即执行下一个任务。

    ScheduledExecutorService  executorService =Executors.newSingleThreadScheduledExecutor();
//第一次延迟一秒打印,后每三秒打印一次,这里使用了lamda表达式简化,相当于new Runable()
    executorService.scheduleAtFixedRate(() ->System.out.println("fsd"),1,3,TimeUnit.SECONDS);

总结一下就是:scheduleAtFixedRate是按照上一次任务的发起时间计算下一次任务的开始时间。

scheduleWithFixedDelay方法

如果需要任务周期性执行的时候保持固定的时间间隔,应该使用scheduleWithFixedDalay()方法.如下的代码保证上一次任务执行完(不管多久)过10秒之后再执行下一次任务.

    ScheduledExecutorService  executorService =Executors.newSingleThreadScheduledExecutor();
//第一次延迟一秒打印,后每三秒打印一次,这里使用了lamda表达式简化,相当于new Runable()
    executorService.scheduleWithFixedDelay(() ->System.out.println("fsd"),1,3,TimeUnit.SECONDS);

总结一下就是:.scheduleWithFixedDelay以上一次任务的结束时间计算下一次任务的开始时间
**注意:
如果ExecutorService被关闭,或者在任务执行过程中抛出了一个异常,那么周期性执行的任务将会终止.。所以最好在Runable中的run方法中捕获所有异常,保证循环的进行,如下:

public class MyThread implements Runnable{
 @Override
    public void run() {
        try { 
            int sleepNumber = random.nextInt(3);
            if(sleepNumber ==2){
                    int error = 1/0;
                        }
        } catch (Exception e) {
            e.printStackTrace();
        }
}

HDFS老化管理中用的Timer

作者:魂之挽歌w
链接:https://www.jianshu.com/p/7de47a45edf4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值