ScheduledThreadPoolExecutor 클래스

java.util.concurrent.ScheduledThreadPoolExecutor는 ThreadPoolExecutor의 하위 클래스이며 지정된 지연 후 실행되거나 주기적으로 실행되도록 명령을 추가로 예약 할 수 있습니다.

ScheduledThreadPoolExecutor 메서드

Sr. 아니. 방법 및 설명
1

protected <V> RunnableScheduledFuture<V> decorateTask(Callable<V> callable, RunnableScheduledFuture<V> task)

콜 러블을 실행하는 데 사용되는 작업을 수정하거나 바꿉니다.

2

protected <V> RunnableScheduledFuture<V> decorateTask(Runnable runnable, RunnableScheduledFuture<V> task)

실행 파일을 실행하는 데 사용되는 작업을 수정하거나 바꿉니다.

void execute(Runnable command)

필요한 지연없이 명령을 실행합니다.

4

boolean getContinueExistingPeriodicTasksAfterShutdownPolicy()

이 실행기가 종료 된 경우에도 기존 주기적 작업을 계속 실행할지 여부에 대한 정책을 가져옵니다.

5

boolean getExecuteExistingDelayedTasksAfterShutdownPolicy()

이 실행기가 종료 된 경우에도 기존 지연된 작업을 실행할지 여부에 대한 정책을 가져옵니다.

6

BlockingQueue<Runnable> getQueue()

이 실행자가 사용하는 태스크 큐를 리턴합니다.

7

boolean getRemoveOnCancelPolicy()

취소시 취소 된 작업을 작업 대기열에서 즉시 제거해야하는지 여부에 대한 정책을 가져옵니다.

8

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

지정된 지연 후 활성화되는 ScheduledFuture를 만들고 실행합니다.

9

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

지정된 지연 후 활성화되는 원샷 작업을 생성하고 실행합니다.

10

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

지정된 초기 지연 후 먼저 활성화되고 이후에 지정된 기간에 활성화되는 주기적 작업을 생성하고 실행합니다. 즉, initialDelay 후 initialDelay + period, initialDelay + 2 * period 등으로 실행이 시작됩니다.

11

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

지정된 초기 지연 후 먼저 활성화되고 이후에 한 실행의 종료와 다음 실행의 시작 사이에 지정된 지연으로 활성화되는 주기적 작업을 생성하고 실행합니다.

12

void setContinueExistingPeriodicTasksAfterShutdownPolicy (boolean value)

이 실행기가 종료 된 경우에도 기존의 정기 작업을 계속 실행할지 여부에 대한 정책을 설정합니다.

13

void setExecuteExistingDelayedTasksAfterShutdownPolicy (boolean value)

이 실행기가 종료 된 경우에도 기존 지연된 작업을 실행할지 여부에 대한 정책을 설정합니다.

14

void setRemoveOnCancelPolicy(boolean value)

취소시 취소 된 작업을 작업 대기열에서 즉시 제거할지 여부에 대한 정책을 설정합니다.

15

void shutdown()

이전에 제출 한 작업이 실행되지만 새 작업은 수락되지 않는 순서대로 종료를 시작합니다.

16

List<Runnable> shutdownNow()

현재 실행중인 모든 작업을 중지하려고 시도하고 대기중인 작업의 처리를 중지하며 실행을 기다리고 있던 작업 목록을 반환합니다.

17

<T> Future<T> submit(Callable<T> task)

실행을 위해 값을 반환하는 작업을 제출하고 작업의 보류중인 결과를 나타내는 Future를 반환합니다.

18

Future<?> submit(Runnable task)

실행을 위해 실행 가능한 작업을 제출하고 해당 작업을 나타내는 Future를 반환합니다.

19

<T> Future<T> submit(Runnable task, T result)

실행을 위해 실행 가능한 작업을 제출하고 해당 작업을 나타내는 Future를 반환합니다.

다음 TestThread 프로그램은 스레드 기반 환경에서 ScheduledThreadPoolExecutor 인터페이스의 사용법을 보여줍니다.

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

public class TestThread {

   public static void main(final String[] arguments) throws InterruptedException {
      final ScheduledThreadPoolExecutor scheduler = 
         (ScheduledThreadPoolExecutor)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