java stream 去重_java知识总结(六):Stream流

jdk8的新特性:

  1. lambda表达式
  2. 函数式接口
  3. stream流
  4. ...

函数式接口、lambda表达式前文都有总结。

java知识总结(三):函数式接口

java知识总结(五):lambda表达式

本次主要总结一下同样的jdk8新增的特性:stream流。

类包:java.util.stream.Stream

Stream API 借助于同样新出现的 Lambda 表达式,极大的提高编程效率和程序可读性。同时它提供串行和并行两种模式进行汇聚操作,并发模式能够充分利用多核处理器的优势,使用 fork/join 并行方式来拆分任务和加速处理过程。

作用:stream流的作用是把数据转换成流,进行各种操作得到想要的数据。

42a4ae20ff833b3bf66e3553bafb8746.png

Stream流的使用过程 :

一、数据源:

1.集合和数组

  • Collection.stream();//串行流
  • Collection.parallelStream()//并行流
  • Arrays.stream(T array) or Stream.of()

2.从 BufferedReader

  • java.io.BufferedReader.lines()

3.静态工厂

  • java.util.stream.IntStream.range()
  • java.nio.file.Files.walk()

4.自己构建

java.util.Spliterator

5.其他

Random.ints()BitSet.stream()Pattern.splitAsStream(java.lang.CharSequence)JarFile.stream()

二、中间操作

filter(Predicate):过滤

map(fun):映射

flatMap(fun):映射

limit(n):保留n个元素

skip(n):跳过n个元素

distinct():去重

sorted():排序

sorted(Comparator) :排序

peek(fun):映射,没有返回值

三、终止操作

allMatch——检查是否匹配所有元素

anyMatch——检查是否至少匹配一个元素

noneMatch——检查是否没有匹配的元素

findFirst——返回第一个元素

findAny——返回当前流中的任意元素

count——返回流中元素的总个数

max——返回流中最大值 min——返回流中最小值

reduce——归约

collect——收集

forEach(fun)——遍历

forEachOrdered(fun) ——遍历

iterator()——迭代

toArray()——数组

测试实例

List list = Arrays.asList(8,3,4,6,7,9,1); /**测试终止操作*/ //1.判断所有值为偶数 boolean a = list.stream().allMatch(num -> num % 2 == 0); System.out.println(a);//false //2.判断存在数值为偶数 boolean b = list.stream().anyMatch(num -> num % 2 == 0); System.out.println(b);//true //3.判断不存在大于10的数 boolean c = list.stream().noneMatch(num -> num > 10); System.out.println(c);//true //3.返回第一个元素 Optional d = list.stream().findFirst(); System.out.println(d.get());//8 //4.返回任意元素 Optional e = list.stream().findAny(); System.out.println(e.get());//找不到就抛出异常,最好设置默认值 Integer e1 = list.stream().findAny().orElse(0); System.out.println(e1); //5.count 统计数量 long f = list.stream().count(); System.out.println(f);//7 //6.返回最大值 Optional max = list.stream().max(Integer::compareTo); System.out.println(max.get());//9 //7.返回最小值 Optional min = list.stream().min(Integer::compareTo); System.out.println(min.get());//1 //8.归约:求最大值 Optional reduce = list.stream().reduce((r1, r2) -> r1 >= r2 ? r1 : r2); System.out.println(reduce.get());//9 //9.收集:偶数列表 List evenNum = list.stream().filter(num -> num % 2 == 0).collect(Collectors.toList()); System.out.println(evenNum);//[8, 4, 6] //10.遍历 list.stream().forEach(System.out::print);//8346791 //11.迭代器 Iterator iterator = list.stream().iterator(); while (iterator.hasNext()) { System.out.print(iterator.next());//8346791 } //12.toArray Integer[] array1 = list.stream().toArray(in -> new Integer[list.size()]); Integer[] array2 = list.stream().toArray(Integer[]::new); Object[] array3 = list.stream().toArray(); /**测试中间操作*/ //1.filter:过滤 List evenNums = list.stream().filter(num -> num % 2 == 0).collect(Collectors.toList()); System.out.println(evenNums);//[8, 4, 6] //2.map:映射 举例:映射成+2的数据 List map1 = list.stream().map(m1 -> m1+2).collect(Collectors.toList()); System.out.println(map1);//[10, 5, 6, 8, 9, 11, 3] //3.limit:保留前几条 List test1 = list.stream().limit(3).collect(Collectors.toList()); System.out.println(test1);//[8, 3, 4] //4.skip:跳过前几条 List test2 = list.stream().skip(3).collect(Collectors.toList()); System.out.println(test2);//[6, 7, 9, 1] //4.skip:跳过前几条 List test3 = list.stream().distinct().collect(Collectors.toList()); System.out.println(test3);//[8, 3, 4, 6, 7, 9, 1] 尴尬,没有重复的数字 //5.sort:排序 List test4 = list.stream().sorted().collect(Collectors.toList()); System.out.println(test4);//[1, 3, 4, 6, 7, 8, 9]
63215df39ca383ac662017d4b6f9b72b.png

无论工作有多忙,一定要会合理安排时间,抽出时间来学习。

自然中之物,互相关系,互相限制。然其写之于文学及美术中也,必遗其关系限制之处。故写实家亦理想家也。又虽如何虚构之境,其材料必求之于自然,而其构造亦必从自然之法律。故理想家亦写实家也。——王国维

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值