有时候我们需要将数量大的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;
}
版权归原作者 JMzz 所有, 如有侵权,请联系我们删除。