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(){
    
        }
    }
  • 相关阅读:
    svn checkout单个文件
    ubuntu下使用fstab挂载硬盘时,属于root,如何把它改为属于一个用户的(如sgjm)
    TCP/IP 端口号大全
    Netstat命令详解(windows下)
    Linux netstat命令详解
    windows下用cmd命令netstat查看系统端口使用情况
    LR函数基础(一)(二)
    loadrunner error 27796 Failed to connect to server
    安装lr时无法将值Disable Script Debugger 写入注册表
    LR接口性能测试提示Code
  • 原文地址:https://www.cnblogs.com/math-and-it/p/11231892.html
Copyright © 2011-2022 走看看