Scala中方法转函数原理讲解

  在Scala有这样一种语法,被称为方法转函数,实则不然,这其中的本质实际是这个函数调用了这个方法,函数还是函数,方法依然是方法,下面通过代码进行讲解。

  1. 先将最常使用的方式写出来进行讲解
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)
}

很多书籍上可能会这种现象说明为方法转函数,但是严格上来说只是生成了一个新的函数,这个函数的内部调用了这个方法而已,写这个也是希望大家对这个有一个更清晰的认知。

猜你喜欢

转载自blog.csdn.net/AnameJL/article/details/114767927