简介:
Callable和Future,它俩很有意思的,一个产生结果,一个拿到结果。
Callable接口类似于Runnable,从名字就可以看出来了,但是Runnable不会返回结果,并且无法抛出返回结果的异常,而Callable功能更强大一些,被线程执行后,可以返回值,这个返回值可以被Future拿到,也就是说,Future可以拿到异步执行任务的返回值。
代码:public class CallableTest {
public static void main(String[] args) throws Exception {
Callable callable2 = new Callable() {
@Override
public Integer call() throws Exception {
System.out.println("Thread1"+Thread.currentThread().getName());
Thread.sleep(1000);
return new Random().nextInt(100);
}
};
FutureTask futureTask = new FutureTask(callable2);
System.out.println("Thread2"+Thread.currentThread().getName());
new Thread(futureTask).start();
System.out.println(futureTask.get());
System.out.println("Thread2"+Thread.currentThread().getName());
}
}
结果:Thread2main
Thread1Thread-0
17
Thread2main
结论:调用futureTask的get方法会让主线程等待子线程拿到返回值再去执行下一步。但是一般不会立刻调用FutureTask的get方法,而是主线程处理其他操作,需要用到返回值再去调用。
相关文章
- 01-30信息的表示和处理之信息存储
- 01-30海信欧洲区营业收入激增113%,成功巩固在该地区的竞争优势和盈利能力
- 01-30[CodeIgniter4]故障排除和本地开发服务器
- 01-30Hive压缩和存储
- 01-30有关于分布式和SOA的理解
- 01-30线程通信生产者和消费者传统版(sync-wait-notityAll)(lock-await-signal)
- 01-30Hive文件存储格式和hive数据压缩
- 01-30把十进制数(long型)分别以二进制和十六进制形式输出,不能使用printf系列。
- 01-30(4)pyqt5教程--->自定义信号和槽(超级绕....)
- 01-30以太网1000BASE有四种有关传输介质的标准:1000BASE-LX、1000BASE-SX、1000BASE-CX和1000BASE-T