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