猿问

ExecutorService怎样不用shutdown,awaitTermination实现主线程等

ExecutorService es = Executors.newFixedThreadPool(THREADPOOLSIZE+1);


        while(true){

            long startTime2 = System.currentTimeMillis();

            numIids = getIds(batchId, LIMITSIZE);

            if (numIids == null || numIids.isEmpty()) {

                break;

            }

            int i = 0;

            int batchSize = numIids.size() / THREADPOOLSIZE;

            if (numIids.size() > THREADPOOLSIZE) {

                for (i = 0; i < THREADPOOLSIZE; i++) {

                    List<Long> subList = numIids.subList(i * batchSize, ((i + 1) * batchSize));

                    es.submit(() -> {

                        try {

                            compute(batchId, subList);

                        } catch (Exception e) {

                            e.printStackTrace();

                        }

                    });

                }

            }

            if (i * batchSize < numIids.size()) {

                List<Long> subList = numIids.subList(i * batchSize, numIids.size());

                es.submit(() -> {

                    try {

                        compute(batchId, subList);

                    } catch (Exception e) {

                        e.printStackTrace();

                    }

                });

            }

            我想在这里实现等待上面所有子线程完成所有任务,然后向下执行(不关闭线程池中的线程,让这些线程重复使用)

        }

        es.shutdown();

        awaitTerminationQuietly(es);

        }


慕运维8079593
浏览 561回答 3
3回答

慕慕森

可以使用 java.util.concurrent.CountDownLatch 这个类

梵蒂冈之花

看看invokeAll这个方法
随时随地看视频慕课网APP

相关分类

Java
我要回答