需求背景
在实现业务功能时,难免会遇到大数据量处理的情况
比如,业务需要处理100000个订单的信息,需要调用外部接口,但接口请求入参限制了参数IDS个数不能超1000,那么就需要将 100000个订单拆分成 100组数据,分组处理。
找了很多资料,主要是下面两类处理方式:
实现方式
方式一:手写实现
private List<List<String>> splitList(List<String> list, int listSize){
if (null === list || 0 === listSize) {
return new ArrayList();
}
int length = list.size();
int num = ( length + listSize- 1 )/listSize;
List<List<String>> newList = new ArrayList<>(num);
for (int i = 0; i < num; i++) {
int fromIndex = i * listSize;
int toIndex = (i+1) * listSize< length ? ( i+1 ) * listSize: length ;
newList.add(list.subList(fromIndex, toIndex)) ;
}
return newList ;
}
方式二:通过 Guava实现(Guava是一种基于开源的Java库)
import com.google.common.collect.Lists;
private List<List<String>> splitList(List<String> list, int listSize){
return Lists.partition(list, listSize);
}