0


Java实现把List拆分成多个分组的两种方法

有时候我们需要将数量大的List按指定的数量分割成n个小List。(适用场景如:Excel导出的时候数量太大,导致卡顿;数据库批量Insert操作,数目达到一定的量,速度变慢或异常;集合作为SQL中IN的参数,而SQL又有长度限制,且性能会下降,所以需要分批分几次进行查询)

1、使用google guava对List进行分割

需要引入google guava依赖,引入后可以使用,简单方便但是需要引入额外依赖

<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>24.1.1</version>
</dependency>

拆分调用

List<T> list = new ArrayList();
//拆分list, 写入拆分的小list的大小
List<List<T>> partition = Lists.partition(list , listSize);

2、自己手写方法实现将List<T>拆分成N个

    List<T> list = new ArrayList();
    //拆分list
    List<List<T>> partition = Lists.partition(list , 200);
    /**
     * 按指定大小,分隔集合,将集合按规定个数分为n个部分
     * 
     * @param list
     * @param subListSize
     * @return
     */
    public static <T> List<List<T>> splitList(List<T> list, int subListSize) {

        if (list == null || list.isEmpty() || subListSize < 1) {
            return Collections.emptyList();
        }

        List<List<T>> result = new ArrayList<>();

        int size = list.size();
        int subListNum = (size + subListSize - 1) / subListSize;

        for (int i = 0; i < subListNum; i++) {
            List<T> subList = list.subList(i * subListSize, ((i + 1) * subListSize > size ? size : subListSize * (i + 1)));
            result.add(subList);
        }

        return result;
    }

3.如果想要进行分页操作,可以参考下面的案例

假设我们的页面大小固定最大值是20个,超过20个,自动设置10个一页,否则就按传入的页面大小来分页,则可以这样来写

    public static Integer PAGE_SIZE = 20;
    public List<Object> getPageList(int pageNo, int pageSize, List<Object> list) {
        if (pageSize > PAGE_SIZE) {
            pageSize = 10;
        }
        List<Object> dataList = new ArrayList<>();
        if (pageSize < PAGE_SIZE) {
            //结果分片处理
            List<List<Object>> partList = Lists.partition(list, pageSize);
            dataList = partList.get(getPageIndex(pageNo, pageSize));
        } else {
            dataList = list;
        }
        return dataList;
    }

    // 获取当前页的list下标
    public int getPageIndex(int pageNum, int pageSize) {
        int indexSum = PAGE_SIZE / pageSize;
        int m = pageNum % indexSum;
        if (m == 0) {
            m = indexSum;
        }
        return m - 1;
    }
标签: java list windows

本文转载自: https://blog.csdn.net/weixin_45740811/article/details/132336749
版权归原作者 JMzz 所有, 如有侵权,请联系我们删除。

“Java实现把List拆分成多个分组的两种方法”的评论:

还没有评论