ExecutorService executor = Executors.newFixedThreadPool(4);
// 定义任务:
List<Future<Integer>> futures = new ArrayList<>();
...
//把待进行线程(任务)放入集合,等待一起执行
futures.add(executorService.submit(runnable);
//批量执行function
for (Future<Integer> future : futures) {
try {
//执行function,子线程全部等待返回
future.get();
} catch (Exception e) {
}
}
//所有线程返回后,关闭线程池
executorService.shutdown();
Future的作用:异步
当做一定运算的时候,运算过程可能比较耗时,有时会去查数据库,或是繁重的计算,比如压缩、加密等,在这种情况下,如果我们一直在原地等待方法返回,显然是不明智的,整体程序的运行效率会大大降低。
我们可以把运算的过程放到子线程去执行,再通过 Future 去控制子线程执行的计算过程,最后获取到计算结果。
Future提供了三个功能:
判断任务是否完成
isDone(): 方法表示任务是否已经完成,若任务完成,则返回true
get():用来获取执行结果,如果在指定时间内,还没获取到结果,就直接返回null
cancel():用来取消任务,如果取消任务成功则返回true,如果取消任务失败则返回false
isCancelled():方法表示任务是否被取消成功,如果在任务正常完成前被取消成功,则返回 true
也就是说Future提供了三种功能:判断任务是否完成,能够中断任务,能够获取任务执行结果
Future里面有个方法 get 是个阻塞方法。当线程池一次性submit多个任务的时候。只有所有的任务全部完成,我们才能用GET按照任务的提交顺序依次返回结果。所以一般来说 我们会轮询future.isDone是否全部完成。或者设置超时机制。