Futures (based on version 22.0)

9 篇文章 0 订阅
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Executors;
import com.google.common.base.Function;
import com.google.common.collect.Sets;
import com.google.common.util.concurrent.FutureCallback;
import com.google.common.util.concurrent.Futures;
import com.google.common.util.concurrent.Futures.FutureCombiner;
import com.google.common.util.concurrent.ListenableFuture;
import com.google.common.util.concurrent.ListeningExecutorService;
import com.google.common.util.concurrent.MoreExecutors;
/**
 * @author Andypan
 * @FuturesTest.java
 * @{describe}
 * @date 2017年7月31日 上午10:09:54
 */
public class FuturesTest
{
public static void main(String[] args) throws InterruptedException, ExecutionException
{
ListeningExecutorService threadPool = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(2));
ListenableFuture<Integer> future1 = threadPool.submit(new CallableTaskTest("a", 23));
ListenableFuture<Integer> future2 = threadPool.submit(new CallableTaskTest("b", 19));


Futures.addCallback(future1, new FutureCallback<Integer>() {


@Override
public void onSuccess(Integer result)
{
System.out.println("success");
}


@Override
public void onFailure(Throwable t)
{
}
}, threadPool);


ListenableFuture<List<Integer>> result = Futures.allAsList(future1, future2);
// System.out.println(result.isDone());
// System.out.println(result.get());


// Iterable<ListenableFuture<Integer>> fuIterable =
// Sets.newHashSet(future1, future2);
// Futures.allAsList(fuIterable);


ListenableFuture<List<Integer>> result2 = Futures.allAsList(Sets.newHashSet(future1, future2));
System.out.println(result2.get());


ListenableFuture<List<Integer>> result3 = Futures.successfulAsList(Sets.newHashSet(future1, future2));
System.out.println(result3.get());


ListenableFuture<String> transResult = Futures.transform(future1, new Function<Integer, String>() {


@Override
public String apply(Integer input)
{


return input + " str";
}
}, threadPool);


/* ListenableFuture<String> transResult = */
// Futures.transformAsync(future2, new AsyncFunction<Integer, String>()
// {
//
// @Override
// public ListenableFuture<String> apply(Integer input) throws Exception
// {
//
// return null;
// }
// }, threadPool);


System.out.println(transResult.get());


FutureCombiner<Integer> combiner = Futures.whenAllComplete(Sets.newHashSet(future1, future2));
ListenableFuture<String>  combinerComplete = combiner.call(new Callable<String>() {


@Override
public String call() throws Exception
{


return "combiner succeed !!!";
}
}, threadPool);

System.out.println(combinerComplete.get());
threadPool.shutdown();
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值