背景
是的,如果你想搜寻 List 汇合,在 Java 8 之前能够应用本身的 contains/ indexOf 办法来查找元素,但仅限是残缺元素,而不能含糊搜寻或者自定义搜寻,这时候的确只能遍历。
但当初都 2021 年了,你还在应用传统的遍历汇合的形式搜寻 List 汇合元素吗?
那你就太 out 了,应用 Java 8 中的 Stream 搜寻元素,一行代码即可搞定,而且还真的很优雅!这篇不会介绍 Stream 根底,Stream 系列我之前写过一个专题了,不懂的关注公众号 Java 技术栈,而后在公众号 Java 教程菜单中浏览。
Stream 搜寻
在 Java 8 中,能够将 List 汇合转换成 Stream,Stream 提供了一系列弱小的搜寻性能,比方:filter、find*、*Match 等办法,一行代码就能搞定搜寻。
比方当初有初始数据:
public static List<User> list = new ArrayList<>();
/**
* @author: 栈长
* @from: 公众号 Java 技术栈
*/
@BeforeEach
public void initList() {list.add(new User("公众号 Java 技术栈 -Petty", 22, 1));
list.add(new User("公众号 Java 技术栈 -Tom", 38, 1));
list.add(new User("公众号 Java 技术栈 -Jessica", 43, 0));
list.add(new User("公众号 Java 技术栈 -John", 15, 1));
list.add(new User("公众号 Java 技术栈 -Lily", 25, 0));
list.add(new User("公众号 Java 技术栈 -Lambs", 28, 0));
list.add(new User("公众号 Java 技术栈 -Jack", 45, 1));
list.add(new User("公众号 Java 技术栈 -Addy", 9, 0));
list.add(new User("公众号 Java 技术栈 -Bob", 61, 1));
list.add(new User("公众号 Java 技术栈 -Candy", 26, 0));
}
用户信息别离为:姓名、年龄、性别。
filter(过滤)
应用 filter 办法实现自定义搜寻,比方搜寻 List\<User\> 汇合中 所有姓名含有 c 的人 :
/**
* 汇合过滤
* @author: 栈长
* @from: 公众号 Java 技术栈
*/
@Test
public void filter() {System.out.println("搜寻所有姓名含有 c 的人");
list.stream().filter(u -> u.getName().contains("c")).forEach(System.out::println);
}
输入后果:
findFirst(查找第一个)
查找 Stream 中的第一个元素,比方搜寻 List\<User\> 汇合中 第一个年经大于 30 的人 :
/**
* 汇合搜寻第一个
* @author: 栈长
* @from: 公众号 Java 技术栈
*/
@Test
public void findFirst() {System.out.println("搜寻第一个年经大于 30 的人");
User user = list.stream().filter(u -> u.getAge() > 30).findFirst().get();
System.out.println(user);
}
输入后果:
示例是须要先 filter 再 findFirst,但如果不要条件的话,filter 就不是必须的。
Stream 根底不懂的能够关注公众号 Java 技术栈,而后在公众号 Java 教程菜单中浏览写的 Java 系列教程。
findAny(查找任意一个)
查找 Stream 中的任意一个元素,比方搜寻 List\<User\> 汇合中 任意一个年经大于 30 的人 :
/**
* 汇合搜寻任意一个
* @author: 栈长
* @from: 公众号 Java 技术栈
*/
@Test
public void findAny() {System.out.println("搜寻任意一个年经大于 30 的人");
User user = list.stream().filter(u -> u.getAge() > 30).findAny().get();
System.out.println(user.getName());
}
输入后果:
为什么后果和 findFirst 一样?和 findFirst 有什么区别呢?
findAny 是查找任意一个元素,在串行流中如果数据较少,个别会返回第一个元素,但在并行流中它返回的后果就不确定了,它可能是流中的任何元素。
findAny 的目标是为了进步并行流操作的性能,但如果须要一个固定的后果,倡议应用 findFirst。
本文所有残缺示例源代码曾经上传:
https://github.com/javastacks…
anyMatch(任意匹配)
查找 Stream 中的元素是否存在任意匹配,比方搜寻 List\<User\> 汇合中 是否存在 XX 人 :
/**
* 汇合匹配任意元素
* @author: 栈长
* @from: 公众号 Java 技术栈
*/
@Test
public void anyMatch() {System.out.println("是否存在 Jack:" + list.stream().anyMatch(u -> u.getName().contains("Jack")));
System.out.println("是否存在 Jet:" + list.stream().anyMatch(u -> u.getName().contains("Jet")));
}
输入后果:
*Match 返回的后果是 boolean 类型。
noneMatch(空匹配)
查找 Stream 中的元素是否不存在匹配,比方搜寻 List\<User\> 汇合中 是否不存在 XX 人 :
/**
* 汇合不匹配任意元素
* @author: 栈长
* @from: 公众号 Java 技术栈
*/
@Test
public void noneMatch() {System.out.println("是否不存在 Jack:" + list.stream().noneMatch(u -> u.getName().contains("Jack")));
System.out.println("是否不存在 Jet:" + list.stream().noneMatch(u -> u.getName().contains("Jack")));
}
输入后果:
这个办法的作用就和 anyMatch 相同。
allMatch(全匹配)
查找 Stream 中的元素是否全副匹配,比方搜寻 List\<User\> 汇合中 所有人的年纪是否都大于 XX:
/**
* 汇合匹配全副元素
* @author: 栈长
* @from: 公众号 Java 技术栈
*/
@Test
public void allMatch() {System.out.println("所有人的年纪都大于 3:" + list.stream().allMatch(u -> u.getAge() > 2));
System.out.println("所有人的年纪都大于 30:" + list.stream().allMatch(u -> u.getAge() > 30));
}
输入后果:
总结
以上所有搜寻操作一行代码就能搞定,是不是很简略优雅?
对于 List 之外的汇合都能够转换为 List,再转换为 Stream 再进行搜寻操作,对于 Stream,搜寻几乎就是小儿科,你学废用了吗?
连忙发给身边的共事看看吧,让你们的代码更优雅!
大家如果对 Java 8 新增的知识点(Lambda、Stream、函数式接口等)还不会用的能够关注公众号:Java 技术栈,在 Java 教程菜单中浏览,Java 8+ 系列教程我都写了一堆了。
本文所有残缺示例源代码曾经上传:
https://github.com/javastacks…
欢送 Star 学习,前面 Java 示例都会在这下面提供!
好了,明天的分享就到这里了,前面栈长会分享更多好玩的 Java 技术和最新的技术资讯,关注公众号 Java 技术栈第一工夫推送,我也将支流 Java 面试题和参考答案都整顿好了,在公众号后盾回复关键字 “ 面试 ” 进行刷题。
最初,感觉我的文章对你用播种的话,动动小手,给个在看、转发,原创不易,栈长须要你的激励。
版权申明: 本文系公众号 “Java 技术栈 ” 原创,原创实属不易,转载、援用本文内容请注明出处,剽窃者一律举报+投诉,并保留追究其法律责任的权力。
近期热文举荐:
1.1,000+ 道 Java 面试题及答案整顿 (2021 最新版)
2. 别在再满屏的 if/ else 了,试试策略模式,真香!!
3. 卧槽!Java 中的 xx ≠ null 是什么新语法?
4.Spring Boot 2.5 重磅公布,光明模式太炸了!
5.《Java 开发手册(嵩山版)》最新公布,速速下载!
感觉不错,别忘了顺手点赞 + 转发哦!