Java线程之FutureTask
2016-03-10 16:05
507 查看
FutureTask是Future和Callable的结合体。传统的代码是这样写的
Future f = executor.submit(new Callable());
然后通过Future来取得计算结果。但是,若开启了多个任务,我们无从知晓哪个任务最先结束,因此,若要实现“当某任务结束时,立刻做一些事情,例如记录日志”这一功能,就需要写一些额外的代码。
FutureTask正是为此而存在,他有一个回调函数protected void done(),当任务结束时,该回调函数会被触发。因此,只需重载该函数,即可实现在线程刚结束时就做一些事情。
[java] view plaincopy
public class Test {
public static void main(String[] args) {
ExecutorService executor = Executors.newCachedThreadPool();
for(int i=0; i<5; i++) {
Callable<String> c = new Task();
MyFutureTask ft = new MyFutureTask(c);
executor.submit(ft);
}
executor.shutdown();
}
}
class MyFutureTask extends FutureTask<String> {
public MyFutureTask(Callable<String> callable) {
super(callable);
}
@Override
protected void done() {
try {
System.out.println(get() + " 线程执行完毕!~");
} catch (InterruptedException | ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
class Task implements Callable<String> {
@Override
public String call() throws Exception {
Random rand = new Random();
TimeUnit.SECONDS.sleep(rand.nextInt(12));
return Thread.currentThread().getName();
}
}
Future f = executor.submit(new Callable());
然后通过Future来取得计算结果。但是,若开启了多个任务,我们无从知晓哪个任务最先结束,因此,若要实现“当某任务结束时,立刻做一些事情,例如记录日志”这一功能,就需要写一些额外的代码。
FutureTask正是为此而存在,他有一个回调函数protected void done(),当任务结束时,该回调函数会被触发。因此,只需重载该函数,即可实现在线程刚结束时就做一些事情。
[java] view plaincopy
public class Test {
public static void main(String[] args) {
ExecutorService executor = Executors.newCachedThreadPool();
for(int i=0; i<5; i++) {
Callable<String> c = new Task();
MyFutureTask ft = new MyFutureTask(c);
executor.submit(ft);
}
executor.shutdown();
}
}
class MyFutureTask extends FutureTask<String> {
public MyFutureTask(Callable<String> callable) {
super(callable);
}
@Override
protected void done() {
try {
System.out.println(get() + " 线程执行完毕!~");
} catch (InterruptedException | ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
class Task implements Callable<String> {
@Override
public String call() throws Exception {
Random rand = new Random();
TimeUnit.SECONDS.sleep(rand.nextInt(12));
return Thread.currentThread().getName();
}
}
相关文章推荐
- Java中如何利用Selenium获取元素分析网页内容
- SQLite在Java中的使用
- 深入理解Java虚拟机——程序编译与代码优化 (转)
- 利用btrace在线监控java程序状态
- 在 Eclipse 下利用 gradle 构建系统
- Spring 4.x实现Restful web service
- java spark WordCount
- 动态代理 jdk as cglib asm
- Javac编译器源代码分析
- java实现动态切换上网IP (ADSL拨号上网)
- JAVA 中BIO,NIO,AIO的理解
- Java BIO、NIO、AIO
- Java数据类型和MySql数据类型对应表
- java jvm 参数 -Xms -Xmx -Xmn -Xss 调优总结
- Java中的数据类型
- 利用java开源包进行短信的收发
- Java NIO框架Mina、Netty、Grizzly介绍与对比
- Java常用工具包 Jodd
- Spring Security二
- Spring Security