Tomcat8新特性

java8中有两大重要的改变。一个是Lambda表达式;另一个是Stream API(java.util.stream.*)

lambda写的好可以极大的减少代码冗余,同时可读性也好过冗长的内部类,匿名类。
详情参考:https://www.cnblogs.com/coprince/p/8692972.html
https://www.cnblogs.com/aoeiuv/p/5911692.html
Stream是Java8中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。

一、什么是Stream?
流(Stream)到底是什么呢?
它是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。
它不同于集合的概念(数据),它讲的计算。
(1)、Stream自己不会存储元素。
(2)、Stream不会改变源对象。相反,他们会返回一个持有结果的新Stream。
(3)、Stream操作是延迟执行的。这意味着他们会等到需要结果的时候才执行。

二、Stream的操作三个步骤
(1)、创建Stream
一个数据源(如:集合、数组),获取一个流
(2)、中间操作
一个中间操作链,对数据源的数据进行处理
(3)、终止操作(终端操作)
一个终止操作,执行中间操作链,并产生结果。

java8中的Collection接口被扩展了,提供了两个获取流的方法:
default Stream stream(): 返回一个顺序流;
default Stream parallelStream():返回一个并行流。
在这里插入图片描述
java8中的Arrays的静态方法stream()可以获取数组流:
static Stream stream(T[] array):返回一个流。

由值创建流:可以使用静态方法Stream.of(),通过显示值创建一个流。他可以吸收任意数量的参数。
public staticc Stream(T) of(T …values): 返回一个流。

有函数创建流:可以使用Stream.iterate()和Stream.generate(),创建无限流。

迭代
public static<T> Stream<T> iterate(final T seed, final UnaryOperator<T> f)
生成
public static<T> Stream<T> genetate(Supplier<T> s);

三、Stream中间操作:
筛选与切片:

1.1、filter——接收 Lambda , 从流中排除某些元素。
1.2、limit——截断流,使其元素不超过给定数量。
1.3、 skip(n) ——跳过元素,返回一个扔掉了前 n 个元素的流。若流中元素不足 n 个,则返回一个空流。与 limit(n) 互补
1.4、distinct——筛选,通过流所生成元素的 hashCode() 和 equals() 去除重复元素

映射:
2.1、map-接收Lambda,将元素转换成其他形式或提取信息。接收一个函数作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素。
2.2、flatMap-接收一个函数作为参数,将流中的每个值都转换成另一个流,然后把所有流连接成一个流

排序:

3.1、sorted()—自然排序(Comparable)
3.2、sorted(Comparator com)----定制排序(Comparator)

四、终止操作:
查找与匹配:

	allMatch——检查是否匹配所有元素
    anyMatch——检查是否至少匹配一个元素
    noneMatch——检查是否没有匹配的元素
    findFirst——返回第一个元素
    findAny——返回当前流中的任意元素
    count——返回流中元素的总个数
    max——返回流中最大值
    min——返回流中最小值

归约:
2.1、reduce(T identity, BinaryOperator) / reduce(BinaryOperator) ——可以将流中元素反复结合起来,得到一个值。
收集:
3.1、Collectors.toList()
3.2、Collectors.toSet()
3.3、Collectors.toCollection(HashSet::new)
3.4、Collectors.maxBy()
3.5、Collectors.minBy()
3.6、Collectors.summingDouble()
3.7、Collectors.averagingDouble()
3.8、Collectors.counting()
3.9、Collectors.summarizingDouble()
3.10、分组Collectors.groupingBy()
3.11、多级分组Collectors.groupingBy()
3.12、分区Collectors.partitioningBy()
3.13、组接字符串Collectors.joining()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值