将数据分块执行

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(){

    }
}

 

转载于:https://www.cnblogs.com/math-and-it/p/11231892.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值