线程池ScheduledExecutorService中scheduleAtFixedRate和scheduleWithFixedDelay的区别

1.scheduleWithFixedDelay

ScheduledFuture<?> scheduleWithFixedDelay(Runnable var1, long var2, long var4, TimeUnit var6);
参数解释:    
var1   command:执行线程
var2   initialDelay:初始化延时(程序运行后N秒开始执行线程)
var4   period:前一次执行结束到下一次执行开始的间隔时间(间隔执行延迟时间),从上一次任务运行结束开始计时
var6   unit:计时单位
TestThreadIm testThreadIm1=new TestThreadIm("唱歌");
TestThreadIm testThreadIm2=new TestThreadIm("跳舞");


ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(2);

scheduledExecutorService.scheduleWithFixedDelay(testThreadIm1,5,10, TimeUnit.SECONDS);
scheduledExecutorService.scheduleWithFixedDelay(testThreadIm2,5,10, TimeUnit.SECONDS);
这里我让每个任务执行的时候睡眠了三秒,便于查看结果:

结论:主线程是05运行的,新开的两个子线程都是10开始运行的,这是参数var2(5秒)的效果!然后下一次运行的时候是23(3秒的休眠+10秒的间隔),这是参数var4(10秒)的效果!

2.scheduleAtFixedRate

ScheduledFuture<?> scheduleAtFixedRate(Runnable var1, long var2, long var4, TimeUnit var6);
参数解释:
command:执行线程
initialDelay:初始化延时
period:两次开始执行最小间隔时间,从上一个任务开始运行就开始计时
unit:计时单位

TestThreadIm testThreadIm1=new TestThreadIm("唱歌");
TestThreadIm testThreadIm2=new TestThreadIm("跳舞");


ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(2);

scheduledExecutorService.scheduleAtFixedRate(testThreadIm1,5,10, TimeUnit.SECONDS);
scheduledExecutorService.scheduleAtFixedRate(testThreadIm2,5,10, TimeUnit.SECONDS);

这里我让每个任务执行的时候睡眠了三秒,便于查看结果:

结论:主线程是00运行的,新开的两个子线程都是05开始运行的,这是参数var2(5秒)的效果!然后下一次运行的时候是15(10秒的间隔),这是参数var4(10秒)的效果!明显区别于上一个方法!这里设置的3秒休眠对下一次任务的执行没有影响!

从上面的两个运行试验得出的结论是不是很明显啊?特做个记录方便自己日后复习和学习!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ScheduledExecutorService是Java用来执行定时任务的线程池。它是Executor框架的一种实现,可以在指定的延迟之后或者按固定的时间间隔周期性地执行任务。 使用ScheduledExecutorService可以方便地创建一个线程池,其线程会自动调度执行任务,而不需要手动创建和管理线程ScheduledExecutorService线程池可以根据需要动态地调整线程的数量,提供了更好的灵活性和效率。 使用ScheduledExecutorService来创建一个线程池可以通过Executors类的静态方法newScheduledThreadPool()来实现,例如: ```java ScheduledExecutorService executor = Executors.newScheduledThreadPool(5); ``` 上述代码创建了一个包含5个线程ScheduledExecutorService线程池。 然后,可以使用ScheduledExecutorServiceschedule()方法来安排任务的执行。schedule()方法有多个重载形式,其最常用的形式接受一个Runnable对象和一个延迟时间作为参数,例如: ```java executor.schedule(new RunnableTask(), 5, TimeUnit.SECONDS); ``` 上述代码将会在5秒之后执行RunnableTask任务。 除了schedule()方法外,还有scheduleAtFixedRate()和scheduleWithFixedDelay()方法可以用来周期性地执行任务。scheduleAtFixedRate()方法可以在固定的时间间隔内周期性地执行任务,而scheduleWithFixedDelay()方法则是在任务执行完成后在固定的延迟时间后再次执行任务。 总结起来,ScheduledExecutorService线程池提供了一种方便的方式来执行定时任务,可以根据需要动态调整线程数量,更加灵活和高效。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值