java.util.concurrent 多线程处理list
2014-12-15 16:11
369 查看
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;
}
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;
}
相关文章推荐
- Java实例 改进发射小程序 java.util.concurrent.Executor执行器来处理多任务多线程
- 在JSTL EL中处理java.util.Map,及嵌套List的情况
- java.util.concurrent 多线程框架---线程池编程(四)
- java多线程学习-java.util.concurrent详解(三)ScheduledThreadPoolExecutor
- java.util.concurrent 多线程框架---线程池编程(五)
- java.util.concurrent多线程框架 (转)
- 在JSTL EL中处理java.util.Map,及嵌套List的情况
- java多线程学习-java.util.concurrent详解(二)Semaphore/FutureTask/Exchanger
- java多线程学习-java.util.concurrent详解(二)Semaphore/FutureTask/Exchanger
- java多线程学习-java.util.concurrent详解(四) BlockingQueue
- java.util.concurrent 多线程框架---线程池编程(三)
- 线程池--java.util.concurrent 多线程框架(二)
- 浅谈java.util.concurrent包的并发处理
- java多线程学习-java.util.concurrent详解(一) Latch/Barrier
- java.util.ConcurrentModificationException异常处理方式
- java.util.concurrent 多线程框架---线程池编程(三)
- 在JSTL EL中处理java.util.Map,及嵌套List的情况
- Java5 多线程实践 -- java.util.concurrent
- java多线程学习-java.util.concurrent详解(三)ScheduledThreadPoolExecutor
- list执行remove和add方法时,报java.util.ConcurrentModificationException的原因