zoukankan      html  css  js  c++  java
  • java 多线程处理一个list的集合

    原文:http://blog.csdn.net/jenny8080/article/details/52100312

    import java.util.ArrayList;
    import java.util.List;
    import java.util.concurrent.Callable;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.Future;
    
    public class App {
    
        public static void main(String[] args) {
            try {
                List<String> list = new ArrayList<String>();
                for (int i = 0; i < 1000; i++) {
                    list.add(i + ",");
                }
    
                System.out.println(list2Str(list, 5));
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        public static String list2Str(List<String> list, final int nThreads)
                throws Exception {
            if (list == null || list.isEmpty()) {
                return null;
            }
            StringBuffer ret = new StringBuffer();
    
            int size = list.size();
            ExecutorService executorService = Executors.newFixedThreadPool(nThreads);
            List<Future<String>> futures = new ArrayList<Future<String>>(nThreads);
            for (int i = 0; i < nThreads; i++) {
                final List<String> subList = list.subList(size / nThreads * i, size/ nThreads * (i + 1));
                Callable<String> task = new Callable<String>() {
                    public String call() throws Exception {
                        StringBuffer sb = new StringBuffer();
                        for (String str : subList) {
                            sb.append(str);
                        }
                        return sb.toString();
                    }
                };
                futures.add(executorService.submit(task));
            }
    
            for (Future<String> future : futures) {
                ret.append(future.get());
            }
            executorService.shutdown();
    
            return ret.toString();
        }
    
    }
  • 相关阅读:
    浅谈生成全排列的4种方法
    UVA
    UVA
    UVA
    UVA
    MySQL索引篇
    MySQL事务篇
    MySQL架构篇
    Redis性能调优
    Redis分布式锁
  • 原文地址:https://www.cnblogs.com/shihaiming/p/8553972.html
Copyright © 2011-2022 走看看