zoukankan      html  css  js  c++  java
  • java中的fork-join框架

    import com.google.common.collect.Lists;
    
    import java.util.Arrays;
    import java.util.List;
    import java.util.concurrent.RecursiveTask;
    
    /**
     * 批量插入数据任务类
     * 利用fork-join框架对数据插入任务进行分组,变成分组插入
     *
     * @author wangjing
     */
    public class BatchInsertTask extends RecursiveTask<Integer> {
        /**
         * 要插入的数据
         */
        List<Integer> records;
        private static final Integer OFFSET = 5;
    
        public BatchInsertTask(List<Integer> records) {
            this.records = records;
        }
    
        @Override
        protected Integer compute() {
            //当要插入的数据少于3,则直接插入
            if (records.size() <= OFFSET) {
                return computeDirectly();
            } else {
                //如果要插入的数据大于等于3,则进行分组插入
                int size = records.size();
                int limit = size % OFFSET == 0 ? size / OFFSET : size / OFFSET + 1;
                Integer sum = 0;
                List<BatchInsertTask> taskList = Lists.newArrayList();
                for (int i = 0; i < limit; i++) {
                    int max = OFFSET * (i + 1) > size ? size : OFFSET * (i + 1);
                    BatchInsertTask task = new BatchInsertTask(records.subList(i * OFFSET, max));
                    task.fork();
                    taskList.add(task);
                }
                for (BatchInsertTask task : taskList) {
                    sum += task.join();
                }
                return sum;
            }
        }
    
        /**
         * 真正插入数据的逻辑
         */
        private int computeDirectly() {
            try {
                Thread.sleep((long) (records.size() * 1000));
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("插入了:" + Arrays.toString(records.toArray()));
            return records.size();
        }
    }
    

      

    import java.util.ArrayList;
    import java.util.List;
    import java.util.concurrent.ExecutionException;
    import java.util.concurrent.ForkJoinPool;
    import java.util.concurrent.ForkJoinTask;
    
    /**
     * 练习使用fork-join
     *
     * @author wangjing
     */
    public class TestForkJoin {
        public static void main(String[] args) throws ExecutionException, InterruptedException {
            ForkJoinPool forkJoinPool = new ForkJoinPool(8);
            List<Integer> list = new ArrayList<>();
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
            list.add(1);
    
            BatchInsertTask batchInsertTask = new BatchInsertTask(list);
            ForkJoinTask<Integer> reslut = forkJoinPool.submit(batchInsertTask);
            System.out.println(reslut.get());
         forkJoinPool.shutdown();
    } }

      

  • 相关阅读:
    【LOJ】 #2015. 「SCOI2016」妖怪
    【LOJ】#2016. 「SCOI2016」美味
    【LOJ】 #2008. 「SCOI2015」小凸想跑步
    【LOJ】#2007. 「SCOI2015」国旗计划
    【LOJ】#2006. 「SCOI2015」小凸玩矩阵
    【LOJ】#2172. 「FJOI2016」所有公共子序列问题
    【LOJ】#2173. 「FJOI2016」建筑师
    【LOJ】#2174. 「FJOI2016」神秘数
    【LOJ】#2280. 「FJOI2017」矩阵填数
    【洛谷】P4585 [FJOI2015]火星商店问题
  • 原文地址:https://www.cnblogs.com/wangjing666/p/10139956.html
Copyright © 2011-2022 走看看