关闭

ListenableFuture

752人阅读 评论(0) 收藏 举报
分类:
转载自:http://www.cnblogs.com/hupengcool/p/3991310.html

ListenableFuture的说明

       Guava定义了ListenableFuture接口并继承了JDK concurrent包下的Future接口,ListenableFuture允许注册回调方法(callbacks),在运算(多线程执行)完成的时候进行调用,或者在运算(多线程执行)完成后立即执行。这样简单的改进,使得可以明显的支持更多的操作,这样的功能在JDK concurrent中的Future是不支持的。在高并发并且需要大量Future对象的情况下,推荐尽量使用ListenableFuture来代替。
       ListenableFuture中的基础方法是addListener(Runnable, Executor), 该方法会在多线程运算完的时候,在Executor中执行指定的Runnable。

ListenableFuture的创建和使用

        对应JDK中的ExecutorService.submit(Callable)提交多线程异步运算的方式,Guava 提供了ListeningExecutorService接口, 该接口返回 ListenableFuture,而相应的ExecutorService返回普通的Future。将 ExecutorService 转为ListeningExecutorService,可以使用MoreExecutors.listeningDecorator(ExecutorService)进行装饰。

举例说明:
ListeningExecutorService pool = MoreExecutors
      .listeningDecorator(Executors.newFixedThreadPool(7));
向这个ListeningExecutorService提交Callable任务
ListenableFuture<String> future = pool.submit(new Callable<String>() {
	@Override
	public String call() throws Exception {
		Thread.sleep(1000 * 3);
		return "Task done !";
	}
});
添加Listener:
Futures.addCallback(future, new FutureCallback<String>() {
	@Override
	public void onSuccess(String result) {
		System.out.println(result);
	}

	@Override
	public void onFailure(Throwable t) {
		t.printStackTrace();
	}
});

当future任务正常执行完毕后,就会调用onSuccess()方法。









0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

ListenableFuture异步多线程代码实现

1、前言 2、 3、代码实现 package future; import java.util.ArrayList; import java.util.HashMap; impor...
  • pistolove
  • pistolove
  • 2016-11-29 11:02
  • 2552

Guava Futures异步回调机制源码解析

1、前言           在前两篇文章中简单阐述了Java Future 和Guava ListenableFuture及其相关的应用。我们发现Guava ListenableFuture提供了...
  • pistolove
  • pistolove
  • 2016-06-25 13:59
  • 5664

Guava之ListenableFuture(链式回调)

上一篇文章,只是简单地介绍了用guava的ListenableFuture实现异步,那如果需要多重回调呢? 方法 描述 transform(ListenableFuture, AsyncFu...
  • u011499747
  • u011499747
  • 2016-03-28 13:12
  • 1147

Guava并发:ListenableFuture使用介绍以及示例

最近在写新一代devopts东西,里面有一个异步并发场景,那就是微服务的单个服务注册中心,所有的微服务都需要在etcd中进行注册,这其中涉及到了ListenableFuture 下去查了写相关的资料...
  • lb7758zx
  • lb7758zx
  • 2017-07-04 14:23
  • 246

Guava之ListenableFuture(链式回调)

上一篇文章,只是简单地介绍了用guava的ListenableFuture实现异步,那如果需要多重回调呢? 方法 描述 transform(ListenableFuture, AsyncFu...
  • u011499747
  • u011499747
  • 2016-03-28 13:12
  • 1147

ListenableFuture in Guava

ListenableFuture的说明    并发编程是一个难题,但是一个强大而简单的抽象可以显著的简化并发的编写。出于这样的考虑,Guava 定义了 ListenableFuture接口并继承了J...
  • pincharensheng
  • pincharensheng
  • 2016-07-28 10:39
  • 90

google Guava包的ListenableFuture解析

并发编程是一个难题,但是一个强大而简单的抽象可以显著的简化并发的编写。出于这样的考虑,Guava 定义了 ListenableFuture接口并继承了JDK concurrent包下的Future 接...
  • jackyechina
  • jackyechina
  • 2016-09-30 13:44
  • 1723

Guava ListenableFuture实现异步非阻塞调用

为了保证系统响应迅速,需要寻找一种方法能够使调取接口能够异步执行,而Java正好提供了类似的方法,在java.util.concurrent中包含了Future相关的类,运用其中的一些类可以进行异步计...
  • zbw18297786698
  • zbw18297786698
  • 2017-06-18 10:52
  • 442

guava ListenableFuture

Guava 定义了 ListenableFuture扩展了Future接口. 允许注册回调方法.Futures.addCallback(ListenableFuture,FutureCallback,...
  • imduan
  • imduan
  • 2016-10-13 20:03
  • 122

Guava中并发ListenableFuture使用

最近在项目中要优化接口,发现guava并发编程中的ListenableFuture比较适合,所以就用上了。感觉还不错,分享一下。使用场景是这样的,客户端需要上传数据到服务端,涉及到几个表的插入。之前都...
  • csujiangyu
  • csujiangyu
  • 2016-05-19 14:28
  • 3263
    个人资料
    • 访问:276225次
    • 积分:5209
    • 等级:
    • 排名:第6144名
    • 原创:202篇
    • 转载:240篇
    • 译文:0篇
    • 评论:23条