时间:2021-05-20
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; }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在Perl中有一些专门用于处理列表数据的模块,比如说List::Util模块,该模块包含在标准库中,能提供各种高效的常见列表处理工具。因其用C语言来实现,速度一
java有三种集合,包括Set、List和Map,它们都处于java.util包中,Set、List和Map都是接口,它们有各自的实现类。 1、Set中的对象
java.util中的集合类包含Java中某些最常用的类。最常用的集合类是List和Map。List的具体实现包括ArrayList和Vector,它们是可变大
分析Github3000个开源项目,粗略统计如下。括号内的数字是使用频率0-3000.下面的列表显示不全,完整的请看完整列表。1.java.util.List(
本文实例讲述了java实现递归文件列表的方法。分享给大家供大家参考。具体如下:FileListing.java如下:importjava.util.*;impo