遇见背景:请求接口限制参数值数量不大于200,需要对值进行分片,多次请求接口。
<!-- 引入一个即可 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-collections4</artifactId>
<version>4.4</version>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>30.1.1-jre</version>
</dependency>
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
import org.apache.commons.collections4.ListUtils;
import com.google.common.collect.Lists;
public class Test7 {
public static void main(String[] args) {
List<String> students = Arrays.asList("Jerry001","Jerry002","Jerry003",
"Jerry004","Jerry005","Jerry006","Jerry007","Jerry008","Jerry009","Jerry010");
//下面的分片都是3个数据一组
List<List<String>> shardingList = shardingList(students, 3);
for (List<String> list : shardingList) {
System.out.println(list.toString());
}
System.out.println("================");
//
List<List<String>> partition = org.apache.commons.collections4.ListUtils.partition(students, 3);
for (List<String> list : partition) {
System.out.println(list.toString());
}
System.out.println("================");
List<List<String>> partition2 = com.google.common.collect.Lists.partition(students, 3);
for (List<String> list : partition2) {
System.out.println(list.toString());
}
}
/**
* 自己实现的分片方法
* @param list 需要分片的集合
* @param spiltnum 多少数据一组
* @return
*/
public static <T> List<List<T>> shardingList(List<T> list, int size) {
if (Objects.isNull(list) || list.size() == 0) {
throw new NullPointerException("List must not be null");
}
if (size <= 0) {
throw new IllegalArgumentException("Size must be greater than 0");
}
List<List<T>> groupinglist = new ArrayList<>();
int num = list.size() % size == 0 ? list.size() / size : list.size() / size + 1;
for (int i = 1; i <= num; i++) {
if (i == num) {
groupinglist.add((List<T>) list.subList((i - 1) * size, list.size()));
} else {
groupinglist.add((List<T>) list.subList((i - 1) * size, i * size));
}
}
return groupinglist;
}
}
输出结果:
[Jerry001, Jerry002, Jerry003]
[Jerry004, Jerry005, Jerry006]
[Jerry007, Jerry008, Jerry009]
[Jerry010]
================
[Jerry001, Jerry002, Jerry003]
[Jerry004, Jerry005, Jerry006]
[Jerry007, Jerry008, Jerry009]
[Jerry010]
================
[Jerry001, Jerry002, Jerry003]
[Jerry004, Jerry005, Jerry006]
[Jerry007, Jerry008, Jerry009]
[Jerry010]