Java Feature异步计算/异步任务

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是否全部完成。或者设置超时机制。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值