java多线程分段并行处理liat集合数据

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.*;

public class test4_thread4 {

public static void main(String[] args) {
List<String> list = new ArrayList<String>();

for (int i = 1; i <= 5; i++) {
list.add(i + "");
}
long l = System.currentTimeMillis();
new test4_thread4().importData(list,5);
System.out.println(System.currentTimeMillis()-l);
}
public void importData(List list,int count) {
//分count一组
int listsize = list.size();
//线程数
int RunSize = (listsize / count) + 1;
ThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(RunSize);
CountDownLatch countDownLatch = new CountDownLatch(RunSize);
for (int i = 0; i < RunSize; i++) {
List newList = null;
if ((i + 1) == RunSize) {
int startIndex = (i * count);
int endIndex = list.size();
newList = list.subList(startIndex, endIndex);
} else {
int startIndex = i * count;
int endIndex = (i + 1) * count;
newList = list.subList(startIndex, endIndex);
}
ImportTask task = new ImportTask(newList, countDownLatch);
executor.execute(task);
}
try {
countDownLatch.await();//主线程等待所有线程完成任务
} catch (InterruptedException e) {
e.printStackTrace();
}

// 所有线程完威任务后的一些业务
System.out.println("完成! ");
executor.shutdown();
}
class ImportTask implements Runnable{
private List list;
private CountDownLatch countDownLatch;
ImportTask(List newList,CountDownLatch countDownLatch){
this.list = newList;
this.countDownLatch = countDownLatch;
}
@Override
public void run() {
int size = list.size();
if (size > 0){
for (int i = 0; i < size; i++) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

System.out.println(list.size());
}
countDownLatch.countDown();
}
}
}
posted @   张安东  阅读(806)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示