Future、Callable、FutureTask、Runnable它们的关系你弄懂了吗

引言

  • 看到标题一下子好几个名称,很可能你都知道、都听过、看过,但是你真是理清楚了它们的关系了吗?
  • 在这个知识泛滥、技术焦虑的时刻,人人嘴里喷着高并发、大数据、分布式,很多估计对这个一头雾水,无论在开发还是面试过程中,一知半解还不如不知。

Runnable/Thread

  • 通常情况下的耗时操作会交给多线程来处理,Java中开启一个新线程很容易,继承自Thread或实现Runnable接口。下面是常规操作。

 

彻底搞懂Future、Callable、FutureTask、Runnable

 

 

  • 开启多线程很多时候是为了利用CPU的多核能力。new Thread()或实现Runnable很容易实现,那为何还需要Future、Callable呢?是JDK开发者嫌头发多了吗?
  • 通常情况下我们只管一顿操作,开启线程扔出去,至于返回值我们开发中好像从来没管过。其实无论是new Thread()还是实现Runnable在执行完了都是无法获取执行结果的,不是我们不想管而是管不了。至于线程执行成功还是失败,很多时候都是听天由命,因为大多情况下我们默认这个执行操作肯定会成功。出了问题也只能追日志了。
  • 通过共享变量或者线程通信的方式倒是可以间接获取执行结果,但是相信我以你的
  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值