zoukankan      html  css  js  c++  java
  • 将数据分块执行

    public abstract class PartitionedExecution {
    private int size;
    private int interval;
    private static int DEFAULT_INTERVAL = 100000;
    public PartitionedExecution(int size){
    this.size=size;
    this.interval = DEFAULT_INTERVAL;
    }
    public PartitionedExecution(int size,int interval){
    this.size=size;
    this.interval=interval;
    }

    public void totalRun(){
    int cycleIndex = size/interval;
    int i = 0;
    for(;i<cycleIndex;i++) {
    int start = i*interval;
    int end = (i+1)*interval;
    stepRun(start,end,i);
    }
    if(size % interval != 0)
    stepRun(i*interval,size,i);
    }
    abstract public void stepRun(int start,int end,int now);
    }

    当数据非常大的时候,我们就需要进行分块处理,所以本人抽象成此类。希望能帮到需要的人,同时有任何问题都可以发表评论。有错误我一定在第一时间修改。

    下面是改进版

    public abstract class PartitionedExecution {
        private int size;
        private int interval;
        private static int DEFAULT_INTERVAL = 1000;
    
        public PartitionedExecution(int size){
            this.size=size;
            this.interval = DEFAULT_INTERVAL;
        }
        public PartitionedExecution(int size,int interval){
            this.size=size;
            this.interval=interval;
        }
    
        public void totalRun(){
            int cycleIndex = size/interval;
            int i = 0;
            for(;i<cycleIndex;i++) {
                int start = i*interval;
                int end = (i+1)*interval;
                stepRun(start,end,i);
            }
            if(size % interval != 0)
                stepRun(i*interval,size,i);
        }
    
        /**
         *  当需要用到start,end和now的时候需要重写此方法
         * @param start 当前循环的开始
         * @param end 当前循环的结束
         * @param now 第几次循环 从0开始
         */
        //abstract public void stepRun(int start,int end,int now);
    
        public void stepRun(int start,int end,int now) {
            for(int i = start;i < end;i++) {
                stepRun();
            }
        }
    
        /**
         *  如果无需用到start,end和now的可以重写此方法
         */
        public void stepRun(){
    
        }
    }
  • 相关阅读:
    MyBatis:2
    MyBatis:1
    synchronized锁普通方法和锁静态方法
    打印倒直角三角形
    迭代器模拟for循环
    Python迭代对象与迭代器
    ffmpeg用法(心得体会还有你见过的用法)
    ffmpeg命令选项解释
    ffmpeg一些filter用法、以及一些功能命令
    FFMPEG 实现 YUV,RGB各种图像原始数据之间的转换(swscale)
  • 原文地址:https://www.cnblogs.com/math-and-it/p/11231892.html
Copyright © 2011-2022 走看看