浅析ListenableFuture使用场景及介绍示例
来源:互联网 发布:vue.js 时间戳格式化 编辑:程序博客网 时间:2024/05/22 04:58
ListenableFuture是对原有Future的增强,可以用于监听Future任务的执行状况,是执行成功还是执行失败,并提供响应的接口用于对不同结果的处理。
适用场景:
1、如果一个主任务开始执行,然后需要执行各个小任务,并且需要等待返回结果,统一返回给前端,此时Future和ListenableFuture作用几乎差不多,都是通过get()方法阻塞等待每个任务执行完毕返回。
2、 如果一个主任务开始执行,然后执行各个小任务,主任务不需要等待每个小任务执行完,不需要每个小任务的结果,此时用ListenableFuture非常合适,它提供的FutureCallBack接口可以对每个任务的成功或失败单独做出响应。
3、如果我们希望各个小任务一旦计算完成就拿到结果展示给用户(push出去)或者做另外的计算,就必须使用另一个线程不断的查询计算状态。这样做,代码复杂,而且效率低下。
public class ListenFutureTest { public static void main(String[] args) { testListenFuture(); } public static void testListenFuture() { System.out.println("主任务执行完,开始异步执行副任务1....."); ListeningExecutorService pool = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(5)); ListenableFuture<String> future = pool.submit(new Task()); Futures.addCallback(future, new FutureCallback<String>() { @Override public void onSuccess(String result) { System.out.println("成功,结果是:" + result); } @Override public void onFailure(Throwable t) { System.out.println("出错,业务回滚或补偿"); } }); System.out.println("副本任务启动,回归主任务线,主业务正常返回2....."); }}class Task implements Callable<String> { @Override public String call() throws Exception { TimeUnit.SECONDS.sleep(1); // int a =1/0; return "task done"; }}结果是:
主任务执行完,开始异步执行副任务1.....
副本任务启动,回归主任务线,主业务正常返回2.....
成功,结果是:task done
如果把Task的注释去掉int a =1/0会抛出异常,那么返回会是
主任务执行完,开始异步执行副任务1.....
副本任务启动,回归主任务线,主业务正常返回2.....
出错,业务回滚或补偿
由此可见,如果不采用此方法,需要另外起一个线程单独来计算状态可计算情况,非常麻烦,用ListenableFuture完美解决
0 0
- 浅析ListenableFuture使用场景及介绍示例
- Guava并发:ListenableFuture使用介绍以及示例
- 多线程学习-ListenableFuture使用介绍以及示例
- Guava并发:ListenableFuture使用介绍以及示例
- SQLite介绍及使用场景
- CountDownLatch 使用场景讲解 及代码示例
- BitSet的使用场景及简单示例
- expect介绍及使用示例
- ZooKeeper介绍及典型使用场景
- 一致性Hash介绍及使用场景
- zookeeper的详细介绍及使用场景
- guava ListenableFuture使用
- guava的ListenableFuture使用
- BLToolkit : Reflection.Emit的使用场景、工具包及示例总结
- 线程池(简单介绍及使用示例)
- ICE简单介绍及使用示例
- flume 1.4的介绍及使用示例
- java jodd框架介绍及使用示例
- log.error("异常:", e);与log.error(e.getMessage());区别
- volatile深入分析( 什么时候使用volatile)
- Tensorflow深度学习之softmax
- 使用Lombok消除冗长的java代码
- 【MATLAB】随机抽取有序的mat文件
- 浅析ListenableFuture使用场景及介绍示例
- 可以免费自学编程的12个网站
- WPF数据绑定
- 设计模式之---代理模式
- Node.js系列——(3)连接DB
- 对象缩放纹理自动重复
- Tomcat性能优化
- xshell登录到CentOS7上时出现“The remote SSH server rejected X11 forwarding request.
- [MySQL]在centos6.5下的启动和关闭