Python 官方文档:入门教程 => 点击学习
目录前言一 ListUtils.partition 方法二 Lists.partition 方法三 源码分析四 性能对比总结前言 在工作中经常遇到需要将数组分割成多个子数
在工作中经常遇到需要将数组分割成多个子数组,然后进行批量处理的需求。那有没有比较优雅的实现呢?
经过多次实践,总结出 ListUtils.partition 和 Lists.partition 两种较好实现 。下面对这两种实现分别进行说明。
1.1 引入依赖
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-collections4</artifactId>
<version>4.4</version>
</dependency>
1.2 代码演示
public static void main(String[] args) {
//初始化数组
List<Integer> parList = new ArrayList<>();
IntStream.range(0, 30).forEach(parList::add);
//分割成子数组
List<List<Integer>> subList = ListUtils.partition(parList, 10);
//遍历子数组
subList.forEach(list -> {
System.out.println(String.fORMat("subList size:%s", list.size()));
System.out.println(String.format("list:%s", list.toString()));
});
}
1.3 输出结果
2.1 引入依赖
<dependency>
<groupId>com.Google.guava</groupId>
<artifactId>guava</artifactId>
<version>29.0-jre</version>
</dependency>
2.2 代码演示
public static void main(String[] args) {
//初始化数组
List<Integer> parList = new ArrayList<>();
IntStream.range(0, 30).forEach(parList::add);
//分割成子数组
List<List<Integer>> subList = Lists.partition(parList, 10);
//遍历子数组
subList.forEach(list -> {
System.out.println(String.format("subList size:%s", list.size()));
System.out.println(String.format("list:%s", list.toString()));
});
}
2.3 输出结果
3.1 ListUtils.partition 源码分析
最终 ListUtils.partition 调用 ListUtils.Partition 方法来处理。
ListUtils.Partition 源码如下:
Partition 类作为 ListUtils 静态内部类继承 AbstractList 类。重写了 get 和 size方法。
3.2 Lists.partition 源码分析
Lists.partition 方法最终会调用 new Partition<>(list, size)。
Partition 类源码如下:
Partition 类作为 Lists 静态内部类继承 AbstractList 类。重写了 get 、 size、isEmpty 方法。
由于Lists.partition和ListUtils.partition底层实现都是通过Partition类来实现,性能差不多。
到此这篇关于Java中实现List分隔成子List详解的文章就介绍到这了,更多相关Java List分隔成子List内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Java中实现List分隔成子List详解
本文链接: https://lsjlt.com/news/162045.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0