多线程批量拆分处理List集合任务

List<String> studentList = new LinkedList<>();
        studentList.add("A");
        studentList.add("B");
        studentList.add("C");
        studentList.add("D");
        studentList.add("E");

        studentList.add("F");
        studentList.add("G");
        studentList.add("H");
        studentList.add("I");
        studentList.add("J");

        studentList.add("K");
        studentList.add("L");
        studentList.add("M");
        studentList.add("N");
        studentList.add("O");

        int nThreads = 3;

        int size = studentList.size();
        ExecutorService executorService = Executors.newFixedThreadPool(nThreads);
        List<Future<Integer>> futures = new ArrayList<Future<Integer>>(nThreads);

        for (int i = 0; i < nThreads; i++) {
            final List<String> groupList = studentList.subList(size / nThreads * i, size / nThreads * (i + 1));


            Callable<Integer> task1 = () -> {
                log.info("Print:"+JSONObject.toJSONString(groupList));
                //do your work
                return 1;
            };
          
            futures.add(executorService.submit(task1));
        }
        executorService.shutdown();
        if (!futures.isEmpty() && futures != null) {
            log.info("I AM COPY OVER");
        }

参考:【java】多线程批量拆分List导入数据库_哈士奇-CSDN博客_多线程批量导入数据库

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值