java5线程框架Executor 排程定时功能
2008-12-21 00:22
429 查看
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 ==================
输出如下:
执行一次任务
执行一次任务
执行一次任务
执行一次任务
执行一次任务
执行一次任务
任务取消!
应用场景:延时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 ==================
输出如下:
执行一次任务
执行一次任务
执行一次任务
执行一次任务
执行一次任务
执行一次任务
任务取消!
相关文章推荐
- java5线程框架Executor 排程定时功能
- java线程之Executor框架与线程池
- java5线程框架Executor的用法举例
- Java线程Executor框架详解与使用
- Java 线程 Executor 框架详解与使用
- Java中的线程(九)- Executor框架
- Java并发编程之线程管理(Executor框架12)
- java5线程框架Executor的用法举例
- java线程安全之Executor框架及自定义线程池(十五)
- java5线程框架Executor 线程并发控制
- java5线程框架Executor的用法举例
- Java并发编程之线程管理(Executor框架16)
- Java线程与并发编程实践----并发工具类与Executor框架
- Java并发编程之线程管理(Executor框架15)
- 05 Java JUC 中的 Executor 框架 提交线程
- java使用Executor(执行器)管理线程
- Java并发和多线程(二)Executor框架
- Java微信开发——分享功能的实现(Spring boot框架)
- Java程序员必备知识-多线程框架Executor详解
- [笔记][Java 4 android] [035~044] 内部类、线程和类集框架