首页 > stream filter 用法_JDK1.8新特性Stream和Collectors19个常用示例总结

stream filter 用法_JDK1.8新特性Stream和Collectors19个常用示例总结

312ce1f8a60cf6ac087e9e94e4f579f3.png

关于Stream和Collectors的用法,这应该是总结的最全的文章了,大家可以收藏一下。

一:简介

java.util.Stream 表示能应用在一组元素上一次执行的操作序列。Stream 操作分为中间操作或者最终操作两种,最终操作返回一特定类型的计算结果,而中间操作返回Stream本身,这样就可以将多个操作依次串起来。Stream 的创建需要指定一个数据源,比如 java.util.Collection的子类,List或者Set, Map不支持。Stream的操作可以串行stream()执行或者并行parallelStream()执行。

二:示例

1. forEach 循环

@Testpublic void forEach(){ // 你不鸟我,我也不鸟你 List list = Arrays.asList("you", "don't", "bird", "me", ",",  "I", "don't", "bird", "you"); // 方式一:JDK1.8之前的循环方式 for (String item: list) { System.out.println(item); } // 方式二:使用Stream的forEach方法 // void forEach(Consumer super T> action) list.stream().forEach(item -> System.out.println(item)); // 方式三:方式二的简化方式 // 由于方法引用也属于函数式接口,所以方式二Lambda表达式也可以使用方法引用来代替 // 此种方式就是方式一、方式二的简写形式 list.stream().forEach(System.out::println);}

2. filter 过滤

public class User { private Long id; private String phone; private Integer age;public User(){} public User(Long id, String username, Integer age) { this.id = id; this.username = username; this.age = age; }// Getter & Setter & toString}@Testpublic void filter(){List users = Arrays.asList( new User(1L, "mengday", 28), new User(2L, "guoguo", 18), new User(3L, "liangliang", 17) ); // Stream filter(Predicate super T> predicate); users.stream().filter(user -> user.getAge() > 18).forEach(System.out::println);}

3. map 映射

@Testpublic void map(){ List list = Arrays.asList("how", "are", "you", "how", "old", "are", "you", "?"); //  Stream map(Function super T, ? extends R> mapper); list.stream().map(item -> item.toUpperCase()).forEach(System.out::println);}

4. flatMap

@Testpublic void flatMap(){ List a = Arrays.asList(1, 2, 3); List b = Arrays.asList(4, 5, 6); //  Stream flatMap(Function super T, ? extends Stream extends R>> mapper) List> collect = Stream.of(a, b).collect(Collectors.toList()); // [[1, 2, 3], [4, 5, 6]]  System.out.println(collect); // 将多个集合中的元素合并成一个集合 List mergeList = Stream.of(a, b).flatMap(list -> list.stream()).collect(Collectors.toList()); // [1, 2, 3, 4, 5, 6] System.out.println(mergeList); // 通过Builder模式来构建 Stream stream = Stream.builder().add("hello").add("hi").add("byebye").build();}

5. sorted 排序

@Testpublic void sort(){ List list = Arrays.asList("c", "e", "a", "d", "b"); // Stream sorted(Comparator super T> comparator); // int compare(T o1, T o2); list.stream().sorted((s1, s2) -> s1.compareTo(s2)).forEach(System.out::println);}

6. distinct 去重复

@Testpublic void distinct(){ // 知之为知之,不知为不知 Stream stream = Stream.of("know", "is", "know", "noknow", "is", "noknow"); stream.distinct().forEach(System.out::println); // know is noknow}

7. count 总数量

@Testpublic void count(){ Stream stream = Stream.of("know", "is", "know", "noknow", "is", "noknow"); long count = stream.count(); System.out.println(count);}

8. min、max

@Testpublic void min(){ List list = Arrays.asList("1", "2", "3", "4", "5"); // Optional min(Comparator super T> comparator); Optional optional = list.stream().min((a, b) -> a.compareTo(b)); String value = optional.get(); System.out.println(value);}

9. skip、limit

@Testpublic void skip(){ List list = Arrays.asList("a", "b", "c", "d", "e"); // Stream skip(long n) list.stream().skip(2).forEach(System.out::println); // c、d、e}@Testpublic void limit(){ List list = Arrays.asList("a", "b", "c", "d", "e"); list.stream().skip(2).limit(2).forEach(System.out::println); // c、d}

10. collect

@Testpublic void collect(){ List list = Arrays.asList("a", "b", "c", "d", "e"); // Stream -> Collection List collect = list.stream().collect(Collectors.toList()); // Stream -> Object[] Object[] objects = list.stream().toArray();}

11. concat

@Testpublic void concat(){ List list = Arrays.asList("a", "b"); List list2 = Arrays.asList("c", "d"); Stream concatStream = Stream.concat(list.stream(), list2.stream()); concatStream.forEach(System.out::println);}

12. anyMatch、allMatch

@Testpublic void match(){ // 你给我站住 List list = Arrays.asList("you", "give", "me", "stop"); // boolean anyMatch(Predicate super T> predicate); // parallelStream可以并行计算,速度比stream更快 boolean result = list.parallelStream().anyMatch(item -> item.equals("me")); System.out.println(result);}/*** anyMatch伪代码 * 如果集合中有一个元素满足条件就返回true * @return */public boolean anyMatch() { List list = Arrays.asList("you", "give", "me", "stop"); for (String item : list) { if (item.equals("me")) { return true; } } return false;}

13. reduce 归纳

@Testpublic void reduce(){ Stream stream = Stream.of("you", "give", "me", "stop"); // Optional reduce(BinaryOperator accumulator); Optional optional = stream.reduce((before, after) -> before + "," + after); optional.ifPresent(System.out::println); // you,give,me,stop}

14. findFirst、findAny

@Testpublic void findFirst(){ Stream stream = Stream.of("you", "give", "me", "stop"); String value = stream.findFirst().get(); System.out.println(value);}@Testpublic void findAny(){ Stream stream = Stream.of("you", "give", "me", "stop"); String value2 = stream.findAny().get(); System.out.println(value2);}

15. 流转换成集合

@Testpublic void testToCollection(){ List list = Arrays.asList(1, 2, 3); // [10, 20, 30] List collect = list.stream().map(i -> i * 10).collect(Collectors.toList());  // [20, 10, 30] Set collect1 = list.stream().map(i -> i * 10).collect(Collectors.toSet());  // {key1=value:10, key2=value:20, key3=value:30} Map collect2 = list.stream().map(i -> i * 10).collect(Collectors.toMap(key -> "key" + key/10, value -> "value:" + value));  // [1, 3, 4] TreeSet collect3= Stream.of(1, 3, 4).collect(Collectors.toCollection(TreeSet::new));}@Data@ToString@AllArgsConstructor@RequiredArgsConstructorpublic class User { private Long id; private String username;}@Testpublic void testToMap() {List userList = Arrays.asList( new User(1L, "mengday"), new User(2L, "mengdee"), new User(3L, "mengdy"));// toMap 可用于将List转为Map,便于通过key快速查找到某个valueMap userIdAndModelMap = userList.stream().collect(Collectors.toMap(User::getId, Function.identity()));User user = userIdAndModelMap.get(1L);// User(id=1, username=mengday)System.out.println(user);Map userIdAndUsernameMap = userList.stream().collect(Collectors.toMap(User::getId, User::getUsername));String username = userIdAndUsernameMap.get(1L);// mengdaySystem.out.println(username);}

16. 集合元素拼接

@Testpublic void testJoining(){ // a,b,c List list2 = Arrays.asList("a", "b", "c"); String result = list2.stream().collect(Collectors.joining(",")); // Collectors.joining(",")的结果是:a,b,c 然后再将结果 x + "d"操作, 最终返回a,b,cd String str= Stream.of("a", "b", "c").collect(Collectors.collectingAndThen(Collectors.joining(","), x -> x + "d"));}

17. 元素聚合

@Testpublic void test(){ // 求最值 3 List list = Arrays.asList(1, 2, 3); Integer maxValue = list.stream().collect(Collectors.collectingAndThen(Collectors.maxBy((a, b) -> a - b), Optional::get)); // 最小值 1 Integer minValue = list.stream().collect(Collectors.collectingAndThen(Collectors.minBy((a, b) -> a - b), Optional::get)); // 求和 6 Integer sumValue = list.stream().collect(Collectors.summingInt(item -> item)); // 平均值 2.0 Double avg = list.stream().collect(Collectors.averagingDouble(x -> x));}@Testpublic void test(){// 映射:先对集合中的元素进行映射,然后再对映射的结果使用Collectors操作 // A,B,C Stream.of("a", "b", "c").collect(Collectors.mapping(x -> x.toUpperCase(), Collectors.joining(",")));}

18. 分组

public class User { private Long id; private String username; private Integer type; // Getter & Setter & toString}@Testpublic void testGroupBy(){ List list = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10); // 奇偶数分组:奇数分一组,偶数分一组 // groupingBy(Function super T, ? extends K> classifier) 参数是Function类型,Function返回值可以是要分组的条件,也可以是要分组的字段 // 返回的结果是Map,其中key的数据类型为Function体中计算类型,value是List类型,为分组的结果 Map> result = list.stream().collect(Collectors.groupingBy(item -> item % 2 == 0)); // {false=[1, 3, 5, 7, 9], true=[2, 4, 6, 8, 10]} System.out.println(result); // partitioningBy 用于分成两组的情况 Map> twoPartiton = list.stream().collect(Collectors.partitioningBy(item -> item % 2 == 0)); System.out.println(twoPartiton);   User user = new User(1L, "zhangsan", 1); User user2 = new User(2L, "lisi", 2); User user3 = new User(3L, "wangwu", 3); User user4 = new User(4L, "fengliu", 1); List users = Arrays.asList(user, user2, user3, user4); // 根据某个字段进行分组 Map> userGroup = users.stream().collect(Collectors.groupingBy(item -> item.type)); /** * key 为要分组的字段 * value 分组的结果 * { * 1=[User{id=1, username='zhangsan', type=1}, User{id=4, username='fengliu', type=1}], * 2=[User{id=2, username='lisi', type=2}], * 3=[User{id=3, username='wangwu', type=3}] * } */ System.out.println(userGroup);} // 分组并对分组中的数据统计@Testpublic void testGroupBy2() { Foo foo1 = new Foo(1, 2); Foo foo2 = new Foo(2, 23); Foo foo3 = new Foo(2, 6); List list = new ArrayList<>(4); list.add(foo1); list.add(foo2); list.add(foo3); Map collect = list.stream().collect(Collectors.groupingBy(Foo::getCode, Collectors.summarizingInt(Foo::getCount))); IntSummaryStatistics statistics1 = collect.get(1); IntSummaryStatistics statistics2 = collect.get(2); System.out.println(statistics1.getSum()); System.out.println(statistics1.getAverage()); System.out.println(statistics1.getMax()); System.out.println(statistics1.getMin()); System.out.println(statistics1.getCount()); System.out.println(statistics2.getSum()); System.out.println(statistics2.getAverage()); System.out.println(statistics2.getMax()); System.out.println(statistics2.getMin()); System.out.println(statistics2.getCount());}

19.累计操作

@Testpublic void testReducing(){ // sum: 是每次累计计算的结果,b是Function的结果 System.out.println(Stream.of(1, 3, 4).collect(Collectors.reducing(0, x -> x + 1, (sum, b) -> { System.out.println(sum + "-" + b); return sum + b; }))); // 下面代码是对reducing函数功能实现的描述,用于理解reducing的功能 int sum = 0; List list3 = Arrays.asList(1, 3, 4); for (Integer item : list3) { int b = item + 1; System.out.println(sum + "-" + b); sum = sum + b; } System.out.println(sum); // 注意reducing可以用于更复杂的累计计算,加减乘除或者更复杂的操作 // result = 2 * 4 * 5 = 40 System.out.println(Stream.of(1, 3, 4).collect(Collectors.reducing(1, x -> x + 1, (result, b) -> { System.out.println(result + "-" + b); return result * b; })));}

本号致力于让大家能够学到实用的知识,如果您认为写的不好请在下方评论提出您的建议,如果您认为写的好请给个赞。

更多相关:

  • 枚举类型测试代码: public class EnumTest {public static void main(String[] args) {Size s = Size.SMALL;Size t = Size.LARGE;// s和t引用同一个对象?System.out.println(s == t); //// 是原始数据类...

  • 程序设计思路:分别建立两个类:ScoreInformation类(用来定义学生的基本信息以及设置set和get函数)ScoreManagement类(用来定义实现学生考试成绩录入,考试成绩修改,绩点计算等功能的函数)和一个主函数Text类 (通过输入的数字选项进行功能的实现,因为退出系统代码量极少,所以在主函数中实现此功能) 程序源...

  • package wjf; import java.util.Scanner; public class wjf1{public static void main(String[] args){ //主方法Scanner scan=new Scanner(System.in); System.out.p...

  • 日期:2018.10.07 星期五 博客期:014   一、Java中的位运算 代码如下: 1 package Morts107; 2 3 public class Test107 { 4 public static void main(String[] args) { 5 int z; 6...

  • list_for_each_safeBidirect-list list_for_each_safe().https://biscuitos.github.io/blog/LIST_list_for_each_safe/...

  • /*hanzhiguang coded at 2009.07.30 1:20*/ // nesting_map.cpp : Defines the entry point for the console application. // /*-----------------------------------------------...

  • 已知k个已排序链表头节点指针,将这k个链表合并,合并后仍为有序的 ,返回合并后的头节点 如下三个链表: 合并后的结果如下: 方法一(STL sort算法进行排序): 先将输入的排序链表插入一个迭代器中,vector数组中国呢直接对数组中的链表节点进行按值排序即可 实现算法如下,最终实现源码见文末: bool cmp(Dat...

  • 本题要求实现一个函数,找到并返回链式表的第K个元素。 函数接口定义: ElementType FindKth( List L, int K ); 其中List结构定义如下: typedef struct LNode *PtrToLNode; struct LNode {ElementType Data;PtrToLNode Ne...

  • 一、前述 企业中linux搭建ftp服务器还是很实用的,所以本文针对centoos7和centoos6搭建服务器教程做个总结。 二、具体 1、显示如下图则表示已安装 vsftp软件。如果未显示则需要安装vsftpd软件。 如果没有则通过yarm源进行安装 yum install -y vsftpd 2、安装完成之后 进入到ftp的根...

  • 一、mybatis  环境搭建步骤  第一步:创建 maven 工程第二步:导入坐标第三步:编写必要代码(实体类和持久层接口)第四步:编写 SqlMapConfig.xml第五步:编写映射配置文件第六步:编写测试类 二、编写sqlMapConfig.xml

  • struts 2 结合json 在struts 2中,要结合json的话,其实是不错的选择,最近做一个登陆系统时,可以考虑选择用 struts 2结合json,下面是要点 register页面    

    Drupal6中的表单如果不让修改

    2019独角兽企业重金招聘Python工程师标准>>> 做好的表单,怎么不让用户进行修改。 $form['user'] = array(    '#type'=> 'textfield',    '#title' => '姓名(*)',      '#default_value' => $feedbacks["u...

  • 在asp.net中的数据绑定中,我们经常会用到Eval,不过大家都知道Eval绑定是通过反射来实现的, 而反射势必会对性能造成一定的影响。不过有两种替代的方式来实现绑定数据,对性能略有提高。 1 当数据源为DataTable时,用下面的方式: 后台代码 protected void Page_Load(object sender,...