线程处理集合数据

com.google.common.util.concurrent目录下是各种线程工具类。
这里介绍一下:
ListenableFuture:顾名思义就是可以监听的Future,它是对java原生Future的扩展增强。
MoreExecutors:该工具类,提供了很多静态方法。其中listeningDecorator方法初始化ListeningExecutorService方法,使用此实例submit方法即可初始化ListenableFuture对象。
ListeningExecutorService的invokeAny继承自Jdk原生类,率先返回线程组中首个执行完毕的。
ListeningExecutorService的invokeAll并行执行线程组,等待所有线程执行完毕,适用于批量处理。

   public final List<String> list = Lists.newArrayList("a", "b", "c", "d", "e", "f");

    @Test
    public void testGuava() {
        ListeningExecutorService listeningExecutorService = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(10));
        List<Callable<String>> allThread = Lists.newArrayList();
        for (final String value : list) {
            Callable<String> callable = new Callable<String>() {
                @Override
                public String call() {
                    return value + " 休息了 " + sleepRandom();
                }
            };
            allThread.add(callable);
        }
        try {
            //1. 返回首个执行完毕的值
            //  String date = listeningExecutorService.invokeAny(allThread);
            // 2. 并行执行完所有线程
            List<Future<String>> valueList = listeningExecutorService.invokeAll(allThread);
            for (Future<String> future : valueList) {
                System.out.println(future.get());
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            listeningExecutorService.shutdown();
        }
    }

在Java 8中可以这样实现

 @Test
    public void testJava8() throws Exception {

        ExecutorService executor = Executors.newFixedThreadPool(10);
        List<CompletableFuture> futures = list.stream()
                .map(value -> CompletableFuture.completedFuture(value).thenApplyAsync(s -> s + " 休息了 " + sleepRandom(), executor))
                .collect(Collectors.toList());
        //1. 返回首个执行完毕的值
        // CompletableFuture valueFuture = CompletableFuture.anyOf(futures.toArray(new CompletableFuture[futures.size()]));
        // 2. 并行执行完所有线程
        CompletableFuture valueFutureList = CompletableFuture.allOf(futures.toArray(new CompletableFuture[futures.size()]));
        futures.stream().forEach(f -> {
            try {
                System.out.println(f.get());
            } catch (Exception e) {

            }
        });

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值