通过CyclicBarrier+线程池的方式,同步的方式分页分批次并发高效处理逻辑,将总页数分成多个批次并发执行每页逻辑,每个批次处理DO_MAX_SIZE个页,每个批次等待DO_MAX_SIZE个页数处理完成后才执行下一个批次,并等待所有批次执行完成才处理后续逻辑 以下代码只需要在TODO处添加上自己的逻辑就可以达到处理效果 /** * 线程池初始化,也可用其它初始化方式 */ , , 10L, TimeUnit.SECONDS, new LinkedBlockingDeque<Runnabl