java8-新特性学习

参考学习视频为:https://www.bilibili.com/video/av27063171/?p=1

一、lambda 表达式

  1.  lambda 操作符  ->     符号的左边写传入的参数,右边则是函数式接口的实现方法。

    1. 函数式接口:只有一个实现方法的接口,可以添加 @FunctionalInterface 注解。

  2. lambda 的语法:

    1. 无参数:() -> 运算式;

    2. 有参数:(e) -> 对 e 的运算式;

    3. 多参数:(e,f) -> 对 e f 的运算式;

    4. 有返回值:接口返回类型 = (e,f) -> 对 e f 的运算式;

    5. 关于参数的类型:不需要指定,java会根据上下文进行类型推断,如果非要加,请全部加上类型。

  3. java提供了 四大内置函数式接口:

    1. 消费型接口(无返回值):Consumer<T> 

      1. void accept( T t );

    2. 供给型接口(无参数,有返回):Supplier<T>

      1. T get();

    3. 函数型接口(有参数,也有返回):Function<T,R>

      1. R apply( T t );

    4. 断言型接口(对参数做判断):Predicate<T>

      1. boolean test(T t);

  4. java还提供了四大内置函数接口的拓展接口。

 

二、方法引用

  1. 若lambda 体中的内容有方法已经实现了,就可以通过使用“方法引用”(可以理解为方法引用就是 Lambda 表达式的另一种表现形式)

  2. 方法引用的语法格式:

    1. 对象::实例方法名

      1. 抽象方法的参数、返回值类型和实现方法的参数、返回值类型相同

    2. 类::静态方法名

    3. 类::实例方法名

      1. 第一参数是方法的调用者,第二个参数是方法的参数

 

三、构造器的引用

  1. 格式:calssname :: new

    1. 需要调用的构造器的参数列表要与函数式接口中抽象方法的参数列表保持一致。

  2. 数组的引用: Type[] :: new;

 

四、Stream API

  1. 主要流程:

    1. 创建 Stream 流

      1. 通过collection 提供的 stream()  或 parallelStream()

      2. 通过Arrays 中的静态 stream() 方法 获取数组流

      3. 通过 Stream 中的静态方法 of()

      4. 创建一个无限流(迭代流) 

        1. Stream.iterate(0,(x) -> x + 2)

    2. 中间操作

      1. 筛选、过滤

        1. filter — 接收 Lambda ,从流中排除默写元素。定义一个筛选规则。

        2. limit — 截断流,对流的长度进行操作。

        3. skip(n) — 跳过元素,返回一个扔掉了前n个元素的流。若流中元素不足 n 个,则返回一个空流。与 limit 是互补的。

          1. 也就是说,limit 选取的是前面几个流,而 skip 则是选取的 n 个元素之后的流,没有了,就是一个空流。

        4. distinct — 筛选,通过流所生成元素的 hashcode() 和 equals() 去除重复元素,注意:对象中的 hashcode() 和 equals() 方法默认是调用系统的,如果要定义自己的规则需要重写。

      2. 映照

        1. map — 接收 Lambda ,将元素转换成其他形式或提取信息。接收一个函数作为参数,该函数将会被应用在每一个元素上,并将其映射成一个新的元素。

          1. 简单说:就是定义一个规则,这个规则将会逐个应用在流中的每一个元素上。这个规则可以是一个 Lambda 表达式,也可以是一个函数方法,总之是一个拥有返回值得东西。

        2. flatMap — 接收一个函数作为参数,将流中的每个值都换成另一个流,然后把所有流连接成一个流。

          1. 可以类比  集合中的 add() / addAll() 方法的区别

      3. 排序

        1. sorted — 自然排序(Comparable)

        2. sorted(Comparator com) — 定制排序(Comparator )

      4. 注意:中间操作都是对前一个流进行下一步操作,基础流是前一个的返回流。

    3. 结束操作

      1. 查找、匹配

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

          1. 所有元素是否都符合指定的规则

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

          1. 至少有一个元素符合规则

        3. noneMatch — 检查是否没有匹配所有元素

          1. 没有一个元素符合规则

        4. findFirst — 返回第一个元素

          1. Optional<> 对象 可用于排除一个空指针   op.other() 方法

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

          1. 查找符合条件的任意一个,如果是 stream() 方法 则只会有一种结果,这个是串行流,如果是 parallelStream() 方法,则会是一个并行流,结果就不一定了,参照比重进行随机。

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

          1. 返回一个 Long 类型

        7. max — 返回元素中的最大值

          1. 通过规则返回一个流中最大值,返回值为 Optional<> 类型

        8. min — 返回流中的最小值

      2. 规约

        1. reduce(T identity,BinaryOperator )— 可以将流中元素反复结合起来,得到一个值。

          1. 如果是这种模式下将会的到一个确切类型的返回值。BinaryOperator 是一个二元操作方法,对传入的两个参数进行操作之后返回一个值。这里可以通过 Lambda 进行实现。

        2. reduce(BinaryOperator)

          1. 这个模式下,有可能得到一个空值,所以返回一个 Optional<> 类型的值。

      3. 收集

        1. collect — 将流转换为其他形式。接受一个Collector接口的实现,用于给Stream中元素做汇总的方法。

          1. 如果收集的结果是一个集合,可以通过 Collectors 中的静态方法进行实现。

 

五、对于空指针问题的处理

  1. 提供一个 Optional<> 类型用于接收可能 空指针 的返回值

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值