多线程学习一CompletableFutureDemo使用

package ThreadDemo;


import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.concurrent.*;
import java.util.function.Function;
import java.util.stream.Collectors;


import lombok.var;
import org.apache.poi.ss.formula.functions.T;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import com.alibaba.fastjson.JSON;
import com.google.common.collect.Lists;


public class CompletableFutureDemo<R,T> {
    private static final ExecutorService THREAD_POOL_EXECUTOR = new ThreadPoolExecutor(10, 10, 60L,
            TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(100000));
    public static void main(String[] args) {
        CompletableFutureDemo completableFutureDemo=new CompletableFutureDemo();

        List<Integer>list=new ArrayList<>();
        list.add(999);
        list.add(3);
        list.add(2);
        list.add(3);
        list.add(4);
        list.add(5);
        list.add(6);
        list.add(7);
        list.add(8);
        list.add(9);



    List future2 =  completableFutureDemo.invokeAsyncForList(list,getF(list));


//        CompletableFuture<String> future2 = new CompletableFuture();
        Integer result = (Integer) future2.get(0);
        System.out.println(result);
        Integer result2 = (Integer) future2.get(1);
        System.out.println(result);
        Integer result3 = (Integer) future2.get(2);
        System.out.println(result);
        Integer result4 = (Integer) future2.get(3);
        System.out.println(result);


    }



    public static Function<List<Integer>,List<Integer>> getF(List<Integer> integers){
        return t->{
            System.out.println(integers.size());
            return Collections.singletonList(t.stream().reduce(Integer::sum).orElse(0));
        };
    };


    public  List<T> invokeAsyncForList(List<R> params, Function<List<R>, List<T>> function){
        List<T> resultList = Lists.newArrayList();
        //按指定长度 进行切分
        List<List<R>> paramList = Lists.partition(params,2);
        System.out.println(paramList.size());
        try{
            List<CompletableFuture<List<T>>> futureList = paramList
                    .stream()
                    .map(pa -> CompletableFuture.supplyAsync(() -> function.apply(pa) ,THREAD_POOL_EXECUTOR))
                    .collect(Collectors.toList());

            List<List<T>> joinList = futureList.stream().map(CompletableFuture::join).collect(Collectors.toList());
            joinList.stream().forEach(System.out::println);
            joinList.stream().forEach(resultList::addAll);
        }catch (Exception e) {
            System.out.println(e.getMessage());
        }

        return resultList;
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值