侧边栏壁纸
  • 累计撰写 45 篇文章
  • 累计创建 87 个标签
  • 累计收到 0 条评论

目 录CONTENT

文章目录

Java列表(List)、集合(Collection)分段处理

Even
2022-09-21 / 0 评论 / 0 点赞 / 834 阅读 / 2582 字

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);
    }
0

评论区