scala传递匿名函数简化的原则

以一下这个标准调用为例说明问题。

f((name: String) => {

println(name)

})

i、 参数的类型可以省略,会根据形参进行自动的推导

f((name) => {

println(name)

})

ii、 类型省略之后,如果只有一个参数,则圆括号可以省略;其他情况: 没有参数和参数超过 1 的永远不能省略圆括号

f( name => {

println(name)

})

iii、 匿名函数如果只有一行,则大括号也可以省略

f( name => println(name) )

iv、 如果 参数只出现一次 ,则参数可以省略且后面的参数可以用_代替

f( println(_) )

推导:对于多个参数,但是参数只出现一次 ,那么每个参数可以使用_代替,但是下划线的顺序和参数的顺序是一一对应的。

v、如果可以推断出当前传入的表达式是一个函数体,而不是调用语句,可以直接省略下划线

f( println )

相关推荐
linweidong14 天前
一站式用AI编程神奇Cursor/Trae(VScode环境)开发运行Scala应用
大数据·vscode·后端·大模型·scala·ai编程·cursor
白总Server22 天前
GaussDB 分布式数据库调优(架构到全链路优化)
java·网络·c++·架构·go·scala·数据库架构
小伍_Five23 天前
spark数据处理练习题番外篇【下】
java·大数据·spark·scala
无人赴约的cat1 个月前
【20250607接单】Spark + Scala + IntelliJ 项目的开发环境配置从零教学
大数据·spark·scala
小伍_Five1 个月前
spark数据处理练习题番外篇【上】
java·大数据·spark·scala
渣渣盟1 个月前
基于Scala实现Flink的三种基本时间窗口操作
开发语言·flink·scala
zhojiew1 个月前
关于akka官方quickstart示例程序(scala)的记录
后端·scala
小伍_Five1 个月前
Spark实战能力测评模拟题精析【模拟考】
java·大数据·spark·scala·intellij-idea
黄雪超1 个月前
DataStreamAPI实践原理——快速上手(实操详细版)
大数据·flink·scala
白总Server1 个月前
C++语法架构解说
java·网络·c++·网络协议·架构·golang·scala