本文介绍: 在项目中有时会出现列表很大,无法一次性批量操作,我们需要将列表分成指定大小的几个子列表,一份一份进行操作,本文提供这样的工具类实现这个需求。
前言
在项目中有时会出现列表很大,无法一次性批量操作,我们需要将列表分成指定大小的几个子列表,一份一份进行操作,本文提供这样的工具类实现这个需求。
实现代码
以下为ListUtil工具类代码实现:
public class ListUtils {
public static <T> List<List<T>> partition(final List<T> list, final int size) {
if (list == null) {
throw new NullPointerException("List must not be null");
}
if (size <= 0) {
throw new IllegalArgumentException("Size must be greater than 0");
}
return new Partition<>(list, size);
}
private static class Partition<T> extends AbstractList<List<T>> {
private final List<T> list;
private final int size;
/**
*
* @param list 传入的列表
* @param size 指定的长度,每size个数据切割为一个子列表
*/
private Partition(final List<T> list, final int size) {
this.list = list;
this.size = size;
}
/**
* 获取按指定长度拆分后,索引位置的子列表
* @param index
* @return
*/
@Override
public List<T> get(final int index) {
//获取拆分后子列表的个数
final int listSize = size();
if (index < 0) {
throw new IndexOutOfBoundsException("Index " + index + " must not be negative");
}
if (index >= listSize) {
throw new IndexOutOfBoundsException("Index " + index + " must be less than size " +
listSize);
}
final int start = index * size;
final int end = Math.min(start + size, list.size());
//返回子列表
return list.subList(start, end);
}
@Override
public int size() {
//(传入列表总长度/指定的长度)向上取整,即为拆分后子列表的个数
return (int) Math.ceil((double) list.size() / (double) size);
}
@Override
public boolean isEmpty() {
return list.isEmpty();
}
}
}
执行结果
-
在上述类里写个main方法用以测试结果。
public static void main(String[] args) { List<String> list=new ArrayList<String>(); for (int i = 0; i <= 2000; i++) { list.add(i+""); } //将list每2000条数据拆分成一个子列表 List<List<String>> partition = ListUtils.partition(list, 2000); System.out.println("将list每2000条数据拆分成一个子列表:"); System.out.println("子列表个数:"+partition.size()); System.out.println("第二个子列表的内容:"); partition.get(1).forEach(System.out::print); System.out.println("-------------------------------------------------------"); System.out.println("将list每10条数据拆分成一个子列表:"); List<List<String>> partition1 = ListUtils.partition(list, 10); System.out.println("子列表个数:"+partition1.size()); System.out.println("第三个子列表的内容:"); partition1.get(2).forEach(s -> { System.out.print(s+" "); }); }
-
执行main方法,得到结果如下:
-
分析结果
将list每2000条数据拆分成一个子列表后,子列表个数为2,第一个子列表里的内容{0,1,…,1998,1999},第二个子列表的内容为{2000}。
将list每10条数据拆分成一个子列表后,子列表个数为201,分别为{0,1,…,8,9},……,{1990,1991,…,1998,1999},{2000}。
结果符合我们的要求,通过这个工具类,我们实现了所需功能。
原文地址:https://blog.csdn.net/weixin_46599489/article/details/135505181
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_56116.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。