ScheduledExecutorService 接口



java.util.concurrent.ScheduledExecutorService 接口是 ExecutorService 接口的子接口,支持任务的未来和/或周期性执行。

ScheduledExecutorService 方法

序号 方法及描述
1

<V> ScheduledFuture<V> schedule(Callable<V> callable, long delay, TimeUnit unit)

创建并执行一个 ScheduledFuture,在给定的延迟后启用。

2

ScheduledFuture<?> schedule(Runnable command, long delay, TimeUnit unit)

创建并执行一个一次性动作,在给定的延迟后启用。

3

ScheduledFuture<?> scheduleAtFixedRate(Runnable command, long initialDelay, long period, TimeUnit unit)

创建并执行一个周期性动作,首先在给定的初始延迟后启用,然后以给定的周期重复执行;也就是说,执行将在 initialDelay 后开始,然后是 initialDelay+period,然后是 initialDelay + 2 * period,依此类推。

4

ScheduledFuture<?> scheduleWithFixedDelay(Runnable command, long initialDelay, long delay, TimeUnit unit)

创建并执行一个周期性动作,首先在给定的初始延迟后启用,然后在一次执行终止和下一次执行开始之间以给定的延迟重复执行。

示例

以下 TestThread 程序展示了在基于线程的环境中使用 ScheduledExecutorService 接口。

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;

public class TestThread {

   public static void main(final String[] arguments) throws InterruptedException {
      final ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);

      final ScheduledFuture<?> beepHandler = 
         scheduler.scheduleAtFixedRate(new BeepTask(), 2, 2, TimeUnit.SECONDS);

      scheduler.schedule(new Runnable() {

         @Override
         public void run() {
            beepHandler.cancel(true);
            scheduler.shutdown();			
         }
      }, 10, TimeUnit.SECONDS);
   }

   static class BeepTask implements Runnable {
      
      public void run() {
         System.out.println("beep");      
      }
   }
}

这将产生以下结果。

输出

beep
beep
beep
beep
广告