2.apache commons
================
先在项目的 pom.xml 中添加框架支持,增加以下配置:
org.apache.commons
commons-collections4
4.4
有了 commons 框架之后,只需要使用 ListUtils.partition 方法即可实现分片,如下代码所示:
import org.apache.commons.collections4.ListUtils;
import java.util.Arrays;
import java.util.List;
/**
- commons.collections4 集合分片
*/
public class PartitionExample {
// 原集合
private static final List OLD_LIST = Arrays.asList(
“唐僧,悟空,八戒,沙僧,曹操,刘备,孙权”.split(“,”));
public static void main(String[] args) {
// 集合分片
List<List> newList = ListUtils.partition(OLD_LIST, 3);
newList.forEach(i -> {
System.out.println(“集合长度:” + i.size());
});
}
}
以上代码的执行结果如下图所示:
3.Hutool
========
先在项目的 pom.xml 中添加框架支持,增加以下配置:
cn.hutool
hutool-all
5.7.14
有了 Hutool 框架之后,只需要使用 ListUtil.partition 方法即可实现分片,如下代码所示:
import cn.hutool.core.collection.ListUtil;
import java.util.Arrays;
import java.util.List;
public class PartitionByHutoolExample {
// 原集合
private static final List OLD_LIST = Arrays.asList(
“唐僧,悟空,八戒,沙僧,曹操,刘备,孙权”.split(“,”));
public static void main(String[] args) {
// 分片处理
List<List> newList = ListUtil.partition(OLD_LIST, 3);
newList.forEach(i -> {
System.out.println(“集合长度:” + i.size());
});
}
}
以上代码的执行结果如下图所示:
4.JDKStream
===========
通过 JDK 8 中的 Stream 来实现分片就无需添加任何框架了,具体的实现代码如下:
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
- JDK Stream Partition
*/
public class PartitionByStreamExample {
// 原集合
private static final List OLD_LIST = Arrays.asList(
1, 2, 3, 4, 5, 6);
public static void main(String[] args) {
// 集合分片:将大于 3 和小于等于 3 的数据分别分为两组
Map<Boolean, List> newMap = OLD_LIST.stream().collect(
Collectors.partitioningBy(i -> i > 3)
);
// 打印结果
System.out.println(newMap);
}
}
以上代码的执行结果如下图所示:
此方式的优点的无需添加任何框架,但缺点是只能实现简单的分片(将一个 List 分为两个),并且要有明确的分片条件。比如本篇案例中设置的分片条件就是数组是否大于 3,如果大于 3 就会被归为一组,否则就会被分到另一组。
5.自定义分片
=======
如果你不想引入第三方框架,并且使用 Stream 也无法满足你的需求,你就可以考虑自己写代码来实现分片功能了。因为此方式不常用,所以咱们这里只给出关键方法。
自定义分片功能的关键实现方法是 JDK 自带的 subList 方法,如下图所示:
使用示例如下:
import java.util.Arrays;
import java.util.List;
public class App {
private static final List _OLD_LIST = Arrays.asList(
“唐僧,悟空,八戒,沙僧,曹操,刘备,孙权”.split(“,”));
public static void main(String[] args) {
// 集合分隔
List list = _OLD_LIST.subList(0, 3);
// 打印集合中的元素
list.forEach(i -> {
System.out.println(i);
});
}
}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/7da04018145b9d446fbe3e17ef5d98ae.jpeg)
知其然不知其所以然,大厂常问面试技术如何复习?
1、热门面试题及答案大全
面试前做足功夫,让你面试成功率提升一截,这里一份热门350道一线互联网常问面试题及答案助你拿offer
2、多线程、高并发、缓存入门到实战项目pdf书籍
3、文中提到面试题答案整理
4、Java核心知识面试宝典
覆盖了JVM 、JAVA集合、JAVA多线程并发、JAVA基础、Spring原理、微服务、Netty与RPC、网络、日志、Zookeeper、Kafka、RabbitMQ、Hbase、MongoDB 、Cassandra、设计模式、负载均衡、数据库、一致性算法 、JAVA算法、数据结构、算法、分布式缓存、Hadoop、Spark、Storm的大量技术点且讲解的非常深入
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
bitMQ、Hbase、MongoDB 、Cassandra、设计模式、负载均衡、数据库、一致性算法 、JAVA算法、数据结构、算法、分布式缓存、Hadoop、Spark、Storm的大量技术点且讲解的非常深入**
[外链图片转存中…(img-Z3ROuiQD-1713395724444)]
[外链图片转存中…(img-x540KrgN-1713395724444)]
[外链图片转存中…(img-i2g5otjt-1713395724444)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!