Java并发ScheduledThreadPoolExecutor类 Java并发性ThreadPoolExecutor类 Java并发Futures和Callables java.util.concurrent.ScheduledThreadPoolExecutor是ThreadPoolExecutor的一个子类,并且可以额外调度命令以在给定的延迟后运行,或者定期执行。 ScheduledThreadPoolExecutor方法 Sr.No. 方法和描述 1 protected RunnableScheduledFuture decorateTask(Callable callable,RunnableScheduledFuture task) 修改或替换用于执行可调用任务的任务。 2 protected RunnableScheduledFuture decorateTask(Runnable runnable, RunnableScheduledFuture task) 修改或替换用于执行可运行的任务。 3 void execute(Runnable command) 以零需要的延迟执行命令。 4 boolean getContinueExistingPeriodicTasksAfterShutdownPolicy() 获取关于是否继续执行现有的周期性任务的策略,即使此执行程序已关闭。 5 boolean getExecuteExistingDelayedTasksAfterShutdownPolicy() 即使此执行程序已关闭,也获取是否执行现有延迟任务的策略。 6 BlockingQueue getQueue() 返回此执行程序使用的任务队列。 7 boolean getRemoveOnCancelPolicy() 获取是否应在取消时立即从工作队列中删除已取消的任务的策略。 8 ScheduledFuture schedule(Callable 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 +周期,然后是initialDelay + 2 *周期,依此类推。 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 shutdownNow() 尝试停止所有正在执行的任务,暂停等待任务的处理,并返回正在等待执行的任务列表。 17 Future submit(Callable task) 提交执行的返回值任务,并返回表示未完成任务结果的Future。 18 Future> submit(Runnable task) 提交可执行的任务并返回表示该任务的Future。 19 Future 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 Java并发性ThreadPoolExecutor类 Java并发Futures和Callables