线程池--多线程执行提升数据处理效率

本文介绍如何利用ExecutorService创建固定大小的线程池,实现List1234的数据并行请求。通过Future获取每个请求的结果,确保等待最慢的请求完成而不是累计所有请求的时间。在所有数据读取完毕后进行合并处理,优化了执行效率。
摘要由CSDN通过智能技术生成

采用线程池同步进行 List 1 2 3 4的数据请求
只有数据读取时间为获取最慢的请求 而不是顺序执行下 四次请求的总时间
通过get读取待数据读取完毕后进行数据合并

//线程池
        ExecutorService executor = Executors.newFixedThreadPool(4);
        List<Map<String, Object>> list1 = new ArrayList<>();
        List<Map<String, Object>> list2 = new ArrayList<>();
        Map<String, Map<String, Object>> list3 = new HashMap<>();
        Map<String, String> list4 = new HashMap<>();
        try {
            //查询1
            Future<List<Map<String, Object>>> listFuture1 = executor.submit(() -> new ArrayList<>());
            //查询2
            Future<List<Map<String, Object>>> listFuture2 = executor.submit(() -> new ArrayList<>());
            //查询3
            Future<Map<String, Map<String, Object>>> listFuture3 = executor.submit(() -> new HashMap<>());
            //查询4
            Future<Map<String, String>> listFuture4 = executor.submit(() -> new HashMap<>());

            list1 = listFuture1.get();
            list2 = listFuture2.get();
            list3 = listFuture3.get();
            list4 = listFuture4.get();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            executor.shutdown();
        }
        //后续数据合并处理
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值