在Scala有这样一种语法,被称为方法转函数,实则不然,这其中的本质实际是这个函数调用了这个方法,函数还是函数,方法依然是方法,下面通过代码进行讲解。
- 先将最常使用的方式写出来进行讲解
object CallByName {
def main(args: Array[String]): Unit = {
val func = m _
func(5)
}
// 定义如下方法
def m(x:Int):Unit = println(x * x)
}
执行结果如下:
可以看到,在执行方法func的时候,得到结果就是通过方法m的逻辑计算出来的结果,这种写法看似是将方法m转成了函数func,其实不是。
通过scala shell执行一下大家就很容易看出来原因,首先定义一个方法m,如下所示
再单独执行一下’m _’ 如所图所示
可以看到当我们执行’m _'的时候实际是生成了一个函数,而本身并没有发生变化,而这个函数内也并不是出现了’x * x’这样的逻辑,这个函数内部实际是调用了m方法,只是这个方法和m方法的签名相同,在IDEA中通过Debug也很容易看出来,我这里打了两个断点,如下图所示
通过Debug运行,运行到函数func的时候,如下图所示
再继续执行下一步,如下图所示
可以到,实际还是执行了m方法本身。
通过如下代码可以对“方法转函数”有一个更清晰的认知
object CallByName {
def main(args: Array[String]): Unit = {
val func = m _
/*等价于*/
val func2 = (y:Int) => m(y)
/*等价于*/
val func3 = (v:Int) => {
m(v)
}
func(5)
}
// 定义如下方法
def m(x:Int):Unit = println(x * x)
}
很多书籍上可能会这种现象说明为方法转函数,但是严格上来说只是生成了一个新的函数,这个函数的内部调用了这个方法而已,写这个也是希望大家对这个有一个更清晰的认知。