背景
在一些场景中,我们需要获取多份数据,而这些数据获取的先后顺序是无关的,我们只需要把数据收集齐,然后再对这些数据统一处理。
比如:执行两个任务 task1 和 task2,都执行完毕后,再把两个任务的结果相加。
例如执行 task1 需要 1s,执行 task2 需要 2s,顺序执行,那么总时间是 1s + 2s = 3s。而如果我们用异步的方式,task1 和 task2 同时执行,则能减少响应的时间。
但并行的方式则必须注意,需要等待所有任务执行完毕之后,才能计算最终的结果,因此这就涉及多线程之间的等待。
方案一:Future.get() 获取数据
先创建一个线程池,并使用 ExecutorService.submit() 方法提交两个 Callable 任务。
提交任务后,这俩任务将开始异步并行执行,并返回了 Future 类型的对象,代表一个未来能获取结果的对象。
当我们调用 Future 对象的 get() 方法时,如果提交的任务已经完成,我们就直接获得结果。如果异步任务还没有完成,那么 get() 会阻塞当前线程,直到所有任务都完成后,才能获得执行的结果。
注意:当 submit() 时,任务就已经开始执行,但不会阻塞线程,当 get() 时&#x