Java util.List如何实现列表分段处理

java.util.List 分段

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

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

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

对集合的处理

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

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

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

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

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

自定义泛型方法进行分页

/**
   * 列表数据分组
   * @param source 源数据
   * @param size 根据大小分组
   * @param <T> 泛型
   * @return
   */
  public static <T> List<List<T>> averageAssign(List<T> source, int size){
    List<List<T>> 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<T> 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;
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。