在实现业务功能时,难免会遇到大数据量处理的情况
比如,业务需要处理100000个订单的信息,需要调用外部接口,但接口请求入参限制了参数IDS个数不能超1000,那么就需要将 100000个订单拆分成 100组数据,分组处理。
找了很多资料,主要是下面两类处理方式:
实现方式方式一:手写实现
private List> splitList(List
list, int listSize){ if (null === list || 0 === listSize) { return new ArrayList(); } int length = list.size(); int num = ( length + listSize- 1 )/listSize; List > 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> splitList(List
list, int listSize){ return Lists.partition(list, listSize); }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)