Callable 和Future
来源:互联网 发布:淘宝自动核对地址软件 编辑:程序博客网 时间:2024/05/18 19:45
在Java5之前,线程是没有返回值的,常常为了“有”返回值,破费周折,而且代码很不好写。或者干脆绕过这道坎,走别的路了。
现在Java终于有可返回值的任务(也可以叫做线程)了。
可返回值的任务必须实现Callable接口,类似的,无返回值的任务必须Runnable接口。
执行Callable任务后,可以获取一个Future的对象,在该对象上调用get就可以获取到Callable任务返回的Object了。
下面是个很简单的例子:
import java.util.concurrent.*;
/**
* Java线程:有返回值的线程
*
* @author Administrator 2009-11-5 0:41:50
*/
public class Test {
public static void main(String[] args) throws ExecutionException, InterruptedException {
//创建一个线程池
ExecutorService pool = Executors.newFixedThreadPool(2);
//创建两个有返回值的任务
Callable c1 = new MyCallable("A");
Callable c2 = new MyCallable("B");
//执行任务并获取Future对象
Future f1 = pool.submit(c1);
Future f2 = pool.submit(c2);
//从Future对象上获取任务的返回值,并输出到控制台
System.out.println(">>>"+f1.get().toString());
System.out.println(">>>"+f2.get().toString());
//关闭线程池
pool.shutdown();
}
}
class MyCallable implements Callable{
private String oid;
MyCallable(String oid) {
this.oid = oid;
}
@Override
public Object call() throws Exception {
return oid+"任务返回的内容";
}
}
/**
* Java线程:有返回值的线程
*
* @author Administrator 2009-11-5 0:41:50
*/
public class Test {
public static void main(String[] args) throws ExecutionException, InterruptedException {
//创建一个线程池
ExecutorService pool = Executors.newFixedThreadPool(2);
//创建两个有返回值的任务
Callable c1 = new MyCallable("A");
Callable c2 = new MyCallable("B");
//执行任务并获取Future对象
Future f1 = pool.submit(c1);
Future f2 = pool.submit(c2);
//从Future对象上获取任务的返回值,并输出到控制台
System.out.println(">>>"+f1.get().toString());
System.out.println(">>>"+f2.get().toString());
//关闭线程池
pool.shutdown();
}
}
class MyCallable implements Callable{
private String oid;
MyCallable(String oid) {
this.oid = oid;
}
@Override
public Object call() throws Exception {
return oid+"任务返回的内容";
}
}
>>>A任务返回的内容
>>>B任务返回的内容
Process finished with exit code 0
>>>B任务返回的内容
Process finished with exit code 0
0 0
- java callable和Future
- 多线程Callable和Future
- 线程--Callable和Future
- Callable和Future
- Callable和Future
- Callable、Future和CompletionService
- Callable和Future
- Callable和Future
- Callable和Future简介
- Callable和Future浅析
- Callable和Future
- Future和Callable
- Future和Callable
- Callable和Future
- Callable、Future和FutureTask
- Callable、Future和CompletionService
- Callable和Future
- Callable和Future
- Lucene的分析过程
- thinkphp 联合查询
- ro.serialno
- sql语句-linq语言-lambda表达式对照(不错先记下了。。。)
- 全文检索原理
- Callable 和Future
- 数据结构与算法练习-Number/数字
- 从QR分解到PCA,再到人脸识别(c++实现)
- SQL中union 与union all的用法
- java动态代理(JDK和cglib)
- 排序算法
- JFreeChart的使用
- 【bzoj4000】[TJOI2015]棋盘 dp+矩乘
- C# 的命名空间