c语言sscanf函数的用法是什么
341
2022-11-09
Java中实现List分隔成子List详解
目录前言一 ListUtils.partition 方法二 Lists.partition 方法三 源码分析四 性能对比总结
前言
在工作中经常遇到需要将数组分割成多个子数组,然后进行批量处理的需求。那有没有比较优雅的实现呢?
经过多次实践,总结出 ListUtils.partition 和 Lists.partition 两种较好实现 。下面对这两种实现分别进行说明。
一 ListUtils.partition 方法
1.1 引入依赖
1.2 代码演示
public static void main(String[] args) {
//初始化数组
List
IntStream.range(0, 30).forEach(parList::add);
//分割成子数组
List> 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 输出结果
二 Lists.partition 方法
2.1 引入依赖
2.2 代码演示
public static void main(String[] args) {
//初始化数组
List
IntStream.range(0, 30).forEach(parList::add);
//分割成子数组
List> subList = Lists.partition(parList, 10);
//遍历子数组
subList.forEach(list -> {
System.out.println(String.format("subList size:%s", list.shttp://ize()));
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类来实现,性能差不多。
总结
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~