线程池newScheduledThreadPool使用
newScheduledThreadPool是一个可以周期性执行任务的线程池
可以看到线程池的线程空闲时间为0,缓存队列为DelayedWorkQueue
实际使用:
线程池中1个线程的执行结果:
线程池中2个线程的执行结果:
如在单线程情况下,每个任务耗费1秒,6个任务耗费6秒,则超过了下一次线程调度的5秒周期
单线程执行结果:
如在多线程情况下,每个任务耗费3秒,2个线程下,增加一个任务,7个任务,超过了下一次线程调度的5秒周期,则下一次调度时间为实际任务结束的时间,
如在多个线程下:eg:2个线程下,3秒即可完成6个任务,而3秒小于任务调度周期时间5秒,因此下次按照设置的5秒频率执行
执行结果:
情况一:任务所需执行时间为1秒的时候 ,实际下一次执行时间为1秒 + 默认delay 5秒=6秒
执行结果:
情况二:任务所需执行时间为6秒超过默认delay=5秒的时候 ,实际下一次执行时间为6秒 + 默认delay 5秒=11秒
将上面的run方法中的睡眠时间改成6秒 TimeUnit.SECONDS.sleep(6); 以后
执行结果:
可以发现,scheduleWithFixedDelay方法 任务执行时间1秒小于或者6秒大于默认的delay延迟,下次执行时间均为上次任务完成时间+delay