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 )

相关推荐
渣渣盟21 小时前
Flink流处理:温度跳变检测与状态管理
大数据·flink·scala
小冯不疯7 天前
金蝶云星空与轻易云集成平台数据对接方案
全文检索·scala
howard20059 天前
1.6.2 掌握Scala数据结构 - 列表
scala·不可变列表·可变列表
howard200514 天前
1.6.1 掌握Scala数据结构 - 数组
scala·定长数组·变长数组
渣渣盟15 天前
Flink Table API与SQL流数据处理实战
大数据·sql·flink·scala
howard200518 天前
1.5 掌握Scala内建控制结构
scala·内建控制结构
howard200518 天前
1.1.2 Windows上安装Scala
scala·windows版本
allway219 天前
Debian Regular Expressions
运维·debian·scala