java工具类-列表分段处理

2021-04-25 22:27

阅读:463

标签:sig   数组   方法   fir   stp   result   rabl   apach   ast   

java.util.List 分段

使用google的guava类库对List分段处理

     List intList = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);
        List> subSets = Lists.partition(intList, 3);
List last = subSets.get(2);

  原理是内部封装着我们要分段的List的引用,在subSets.get(index) 语句时,对参数List.subList()动态处理 

对集合的处理

        Collection intCollection = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);
        Iterable> subSets = Iterables.partition(intCollection, 3);
        List firstPartition = subSets.iterator().next();

  使用iterable进行遍历,iterator.next()方法,内部是使用固定size大小的数组循环状态size次数据,然后返回数据

 

使用apache common工具的的List分段处理方法

        ArrayList intList = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);
        List> subSets2 = ListUtils.partition(intList, 3);

  这个方法和guava包的列表分段方法原理是相同的

 

 

 

自定义泛型方法进行分页

    /**
     * 列表数据分组
     * @param source 源数据
     * @param size 根据大小分组
     * @param  泛型
     * @return
     */
    public static  List>  averageAssign(List source, int size){
        List> result = new ArrayList();
        int offset=0;
        boolean isZero = source.size()%size==0;
        int totalPage = source.size()/size + 1;
        int totalSize = source.size();
        while(totalPage-1>=offset){
            List subList = null;
            if(offset == totalPage-1){
                if(isZero){
                    break;
                }
                //最后一段的处理
                subList = source.subList(size * offset, totalSize);
            }else{
                subList = source.subList(size * offset, size * (offset + 1));
            }
            offset++;
            result.add(subList);
        }
        return result;
    }

 

java工具类-列表分段处理

标签:sig   数组   方法   fir   stp   result   rabl   apach   ast   

原文地址:https://www.cnblogs.com/gne-hwz/p/13255489.html


评论


亲,登录后才可以留言!