1,帶有排程功能的例子(測試ScheduledExecutorService)。
應用場景:延時5秒後每秒執行一次task1,task1打印一些信息;延時10秒後執行task2, task2用來取消task1的執行。
=============== ScheduledExecutorServiceTest.java start ==================
package Executor;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;
public class ScheduledExecutorServiceTest {
@SuppressWarnings("unchecked")
public static void main(String[] args)
throws InterruptedException, ExecutionException {
//1 創建一個具有排程功能的線程池
ScheduledExecutorService service = Executors.newScheduledThreadPool(2);
//2 創建一個任務
Runnable task1 = new Runnable() {
public void run() {
System.out.println("執行一次任務");
}
};
//3 延時5秒後每秒執行一次task1;並返回一個Future 對象(通過Future對象可瞭解任務執行情況)
final ScheduledFuture future1 = service.scheduleAtFixedRate(task1, 5, 1, TimeUnit.SECONDS);
//4 生成一個可執行任務(該任務執行完畢可以返回結果 或者 拋出異常;而Runnable接口的run方法則不行)
Callable task2 = new Callable() {
public String call() {
future1.cancel(true);
return "任務取消!";
}
};
//5 延時10秒後執行task2;並返回一個Future 對象(通過Future對象可瞭解任務執行情況)
ScheduledFuture future2 = service.schedule(task2, 10, TimeUnit.SECONDS);
//6 打印task2執行的結果
System.out.println(future2.get());
//7 關閉線程池
service.shutdown();
}
}
=============== ScheduledExecutorServiceTest.java end ==================
輸出如下:
執行一次任務
執行一次任務
執行一次任務
執行一次任務
執行一次任務
執行一次任務
任務取消!