弄懂Runable,Callable,Future之间的关系

JDK1.5之前,我们创建线程有这样两种方式

1.继承Thread类

2.连接实现Runnable接口

但是这两个方法我们都没有返回值,如果需要获取任务返回结果怎么办?

然后在JDK1.5之后,官方就提供了Callable和Future,有获取任务返回结果的方法

ps:我们的Thread类本身也实现了Runnable接口


Runnable接口

我们这个接口有一个run方法,我们的返回值是void类型

Callable接口

有返回值

可以抛出异常


Future接口

Future是用来做我们的异步

我主要有这4个功能

他的功能比Runnable,Callable丰富

取消任务 cancel()

判断任务是否被取消 isCancellde()

判断任务是否执行完成 isDone()

获取任务执行结果 get()

简单理解就是:

我有一个任务,提交给了 Future 来处理。

任务执行期间我自己可以去做任何想做的事情 。并且,在这期间我还可以取消任务以及获取任务的执行状态 。一段时间之后,我就可以 Future 那里直接取出任务执行结果。


FutureTask类来进行进一步理解

我们的FutureTask实现了我们的Runnable接口和我们的Future接口

FutureTask内部可传入Callable或者Runnable对象

传入的Runnable对象会在方法内部转换为Callable对象

FutureTask相当于对Callable进行了封装,管理着任务执行的结果,存储了Callable的call方法的任务执行结果

FutureTask让我们既可以作为一个Runnable被Thread执行,也可以获取Future异步计算得到的结果

相关推荐
Yvonne爱编码4 小时前
JAVA数据结构 DAY1-集合和时空复杂度
java·数据结构·python
m0_736919104 小时前
模板元编程性能分析
开发语言·c++·算法
win x4 小时前
JavaSE(基础)高频面试点及 知识点
java·面试·职场和发展
Terio_my4 小时前
简要 Java 面试题学习
java·开发语言·学习
wbs_scy4 小时前
C++11:类新功能、lambda与包装器实战
开发语言·c++
2301_765703144 小时前
C++中的职责链模式实战
开发语言·c++·算法
好好研究4 小时前
Spring Boot - Thymeleaf模板引擎
java·spring boot·后端·thymeleaf
爬山算法4 小时前
Hibernate(76)如何在混合持久化环境中使用Hibernate?
java·后端·hibernate
编程彩机4 小时前
互联网大厂Java面试:从分布式缓存到消息队列的技术场景解析
java·redis·面试·kafka·消息队列·微服务架构·分布式缓存
她说..5 小时前
策略模式+工厂模式实现单接口适配多审核节点
java·spring boot·后端·spring·简单工厂模式·策略模式