java lamdba表达式详解20200301

1.lamdba表达式 概述

lamdba表达式是基于函数式编程思想,在jdk8中出现的新特性,与面向对象及面向函数编程的scala语言来说,可以说只是其中一部分。下面我们来看看java中的lamdba表达式

什么是函数式接口

  • 1.是java 中的一个普通接口
  • 2.是只包含了一个抽象方法的特殊接口
  • 3.语义化检测注解 @funcationalInterface
    在这里插入图片描述
    如果提供了别的抽象方法 语义化检测就会报错
    在这里插入图片描述
    但是其中可以出现静态方法和默认方法

在这里插入图片描述

函数式接口和lamdba的关系

  • lamdba 表达式其实就是针对函数式接口的简单实现

通过匿名内部类的方式
在这里插入图片描述
其中代码冗余太多 可以写成一下这种lamdba 表达式结构
在这里插入图片描述

jdk 中常见的函数式接口

参见:
https://www.cnblogs.com/Lothlorien/p/11992834.html

lamadba 表达式结构

- 1.声明部分 :lamdba 绑定函数式接口 类型
- 2.参数部分   在()中  和绑定的函数式接口的参数保持一致
- 3.符号  ->
- 4 执行代码块 :{}
如下:
 接口声明 = (参数)-> { 方法体}
参数可以省略类型   
方法体如果只有一行可以省略大括号  
如果返回值return 可以省略

无参数无返回值的lamdba
无参数有返回值的lamdba
在这里插入图片描述

有参数有返回值的lamdba
在这里插入图片描述

lamdba 表达式类型检查

在这里插入图片描述

该lamdba 表达式被解析成为MyInterface 类型 其中的 str list 变量都是自动推导出来的

2.Stream 和lamdba 结合完成业务处理

获取stream对象

  • 集合:
  • Collection.stream()
  • Collection.parallelstream()
  • 数组:
  • Arrays.stream(T t)

中间操作api

  • 中间操作操作结果是一个stream对象,中间操作只记录操作方式,不做具体执行,直到结束操作发生才最终执行
  • 中间操作分为
  • 有状态 数据处理时,不受中间操作影响
  • map/filer/peek/parallel/…
  • 无状态 数据处理时,受中间操作影响
  • distinct/sorted/limit/skip/…

结束操作api

  • 一个stream 一个结束操作
  • 一个stream 一旦执行了结束操作,就会真是的处理数据
  • 短路操作 必须处理完集合中的所有数据
  • foreach/foreachOrdered/toArray/Reduce/collect/min/max/count/…
  • 非短路操作 满足条件即可结束 不用处理所有数据
  • findFirst/findAny/…

stream 操作集合

批量数据-》 stream

在这里插入图片描述

stream-其他类型

在这里插入图片描述

常见api

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值