java.util.concurrent 多线程处理list

本文介绍了一个使用多线程处理部门及人员数据的方法。通过将数据集划分为子集并在多个线程中并行处理,提高了处理效率。每个线程负责修改部门下人员的性别字段,并记录相关信息。
public static void main(String[] args) {
try {
List<Department> list = new ArrayList<Department>();
for (int d = 0; d < 10; d++) {
Department department = new Department();
List<Person> personList = new ArrayList<Person>();
for (int i = 0; i < 3; i++) {
Person person = new Person();
person.setName("name" + "_" + d + "_" + i);
person.setSex((i % 2 == 0) ? "boy" : "girl");
person.setAge(i + "");
personList.add(person);
}
department.setName("deparName" + d);
department.setPersonList(personList);
list.add(department);
}


} catch (Exception e) {
e.printStackTrace();
}


testLogger();
}


public static void formatList(List<Department> list, final int nThreads)
throws Exception {
if (list == null || list.isEmpty()) {
return;
}


StringBuffer ret = new StringBuffer();


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


for (int i = 0; i < nThreads; i++) {
final List<Department> subList = list.subList(size / nThreads * i,
size / nThreads * (i + 1));
initLog4j(i+"");
Callable<List<Department>> task = new Callable<List<Department>>() {
@Override
public List<Department> call() throws Exception {
StringBuffer sb = new StringBuffer();
for (Department department : subList) {
List<Person> personList = department.getPersonList();
for (Person person : personList) {
person.setSex("sex" + person.getSex());
logger.info(person.getName());
}
}
return subList;
}
};
futures.add(executorService.submit(task));
}


for (Future<List<Department>> future : futures) {
List<Department> newList = future.get();
for (Department department : newList) {
for (Person person : department.getPersonList()) {
System.out.println(person.getName() + " : "
+ person.getSex());
}
}
}
executorService.shutdown();


return;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值