คลาส ScheduledThreadPoolExecutor
java.util.concurrent.ScheduledThreadPoolExecutor เป็นคลาสย่อยของ ThreadPoolExecutor และยังสามารถกำหนดเวลาคำสั่งให้ทำงานหลังจากการหน่วงเวลาที่กำหนดหรือเพื่อดำเนินการเป็นระยะ ๆ
เมธอด ScheduleThreadPoolExecutor
ซีเนียร์ | วิธีการและคำอธิบาย |
---|---|
1 | protected <V> RunnableScheduledFuture<V> decorateTask(Callable<V> callable, RunnableScheduledFuture<V> task) แก้ไขหรือแทนที่งานที่ใช้ในการเรียกใช้งาน |
2 | protected <V> RunnableScheduledFuture<V> decorateTask(Runnable runnable, RunnableScheduledFuture<V> task) แก้ไขหรือแทนที่งานที่ใช้ในการรันรันได้ |
3 | 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) สร้างและดำเนินการแอ็คชั่น one-shot ที่เปิดใช้งานหลังจากการหน่วงเวลาที่กำหนด |
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) ส่งงานคืนค่าสำหรับการดำเนินการและส่งคืนอนาคตที่แสดงถึงผลลัพธ์ที่รอดำเนินการของงาน |
18 | Future<?> submit(Runnable task) ส่งงานที่รันได้เพื่อดำเนินการและส่งคืนอนาคตที่แสดงถึงภารกิจนั้น |
19 | <T> Future<T> submit(Runnable task, T result) ส่งงานที่รันได้เพื่อดำเนินการและส่งคืนอนาคตที่แสดงถึงภารกิจนั้น |
ตัวอย่าง
โปรแกรม 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