Runnable, Callable, Future, Task, FutureTask总结

​​​​​​

对象

用法

Runnable

没返回值

Callable

有返回值
Task
  1. extends Runnable
  2. 只有俩方法,run和cancel,都没返回值。

Future

  1. Executor是Runnable和Callable的调度容器(需和Runnable和Callable配套使用)
  2. Future就是对于具体的Runnable或者Callable任务的执行结果进行取消、查询是否完成、获取结果、设置结果操作(虽然runnable还是没有返回值。)
  3. get方法会阻塞,直到任务返回结果
FutureTask
  1. 是一个RunnableFuture,RunnableFuture实现了Runnbale又实现了Future这两个接口。
  2. 它可以包装Runnable和Callable, 由构造函数注入依赖。 
  3. Runnable注入会被Executors.callable()函数转换为Callable 类型,即FutureTask最终都是执行Callable类型的任务
  4. get()函数获取执行结果,该函数会阻塞,直到结果返回
  5. 也就是说,提交给线程池的任务和执行后的结果,都放到同一个FutureTask对象中。提交时用到Task属性,返回结果用到Future属性。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值