public void handle() throws Exception {
// 开始时间
long start = System.currentTimeMillis();
log.info("多线程 : ********** start " + new Date());
//获取待处理数据总数,划分线程
List<String> list = new ArrayList<>(getAllDeviceNumber());
// 每300条数据开启一条线程
int threadSize = 300;
// 总数据条数
int dataSize = list.size();
// 线程数
int threadNum = dataSize / threadSize + 1;
// 定义标记,过滤threadNum为整数
boolean special = dataSize % threadSize == 0;
// 创建一个线程池
ExecutorService exec = Executors.newFixedThreadPool(threadNum);
// 定义一个任务集合
List<Callable<Integer>> tasks = new ArrayList<>();
Callable<Integer> task;
List<String> cutList;
// 确定每条线程的数据
for (int i = 0; i < threadNum; i++) {
if (i == threadNum - 1) {
if (special) {
break;
}
cutList = list.subList(threadSize * i, dataSize);
} else {
cutList = list.subList(threadSize * i, threadSize * (i + 1));
}
List<String> finalCutList = cutList;
task = () -> {
//调用实际处理任务
getLastDataTime(finalCutList);
return 1;
};
// 这里提交的任务容器列表和返回的Future列表存在顺序对应的关系
tasks.add(task);
}
exec.invokeAll(tasks);
// 关闭线程池
exec.shutdown();
log.info("线程任务执行结束");
log.info("线程数" + threadNum + "执行任务消耗了 :" + (System.currentTimeMillis() - start) + "毫秒");
}
spring boot 多线程执行任务
于 2022-04-18 15:09:46 首次发布