引言
- 看到标题一下子好几个名称,很可能你都知道、都听过、看过,但是你真是理清楚了它们的关系了吗?
- 在这个知识泛滥、技术焦虑的时刻,人人嘴里喷着高并发、大数据、分布式,很多估计对这个一头雾水,无论在开发还是面试过程中,一知半解还不如不知。
Runnable/Thread
- 通常情况下的耗时操作会交给多线程来处理,Java中开启一个新线程很容易,继承自Thread或实现Runnable接口。下面是常规操作。
- 开启多线程很多时候是为了利用CPU的多核能力。new Thread()或实现Runnable很容易实现,那为何还需要Future、Callable呢?是JDK开发者嫌头发多了吗?
- 通常情况下我们只管一顿操作,开启线程扔出去,至于返回值我们开发中好像从来没管过。其实无论是new Thread()还是实现Runnable在执行完了都是无法获取执行结果的,不是我们不想管而是管不了。至于线程执行成功还是失败,很多时候都是听天由命,因为大多情况下我们默认这个执行操作肯定会成功。出了问题也只能追日志了。
- 通过共享变量或者线程通信的方式倒是可以间接获取执行结果,但是相信我以你的水平,怕是要996解bug。
Future机制
Callable
- 那既然