Scala的函数作为参数的用法

标签 scala functional-programming

class ClosureClass {
  def printResult[T](f: => T) = {
    println("choice 1")
    println(f)
  }

  def printResult[T](f: String => T) = {
    println("choice 2")
    println(f("HI THERE"))
  }
}

object demo {
  def main(args: Array[String]) {
    val cc = new ClosureClass
    cc.printResult()   // call 1
    cc.printResult("Hi")  // call 2
  }
}

我玩了上面的代码,结果告诉了我。我有两个问题

1) 为什么调用 1 和调用 2 都进入选择 1?

2) 如何传递参数以便进入选项 2。

谢谢,

choice 1
()
choice 1
Hi

最佳答案

类型=> T 表示f 是按名称调用的参数。这意味着 fT 类型,传递给函数的表达式将在使用时计算(而不是在调用函数时计算。

String => T 类型表示 f 是一个 Function[String,T],即 function[String,T] 中的函数 StringT

当你调用 "Hi" 时,一个 String 作为参数,Scala 认为 printResult 有两个选择:

1) => T:在这种情况下,case T 将绑定(bind)到 String,这很好。

2) String => T:这不起作用,因为 String 不是从 String 到任何东西的函数...它不是一个函数。

如何解决这个问题取决于您要做什么。如果你只是想修复 printResult 的调用方式,那么你可以调用它:

val g: (String => String) = (s: String) => s + "***"
cc.printResult(g)

打印:

choice 2
HI THERE***

因为您现在正确地将函数gString 传递给某些T。这里的 TString,因为该函数只是将 *** 添加到传递的任何内容的末尾并返回修改后的字符串。

关于Scala的函数作为参数的用法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10696704/

相关文章:

scala - 这不是尾递归风格的代码吗?

Scala BigDecimal 除法

scala - 在 Spark 中重用连接的数据框

存在类型和类型成员的 Scala 类型推断

functional-programming - Erlang 函数调用 - 为什么将 self() 作为直接参数调用不起作用?

javascript - 将方法转换为以此为第一个参数的函数的函数

haskell - Haskell 中的字节串 : should I use Put or Builder?

haskell - Haskell prelude 函数可以简化为一组核心函数吗?

java - Play Framework (2.4)、sbt (0.13.17) 的热重载以及整个项目完全重新编译的原因

scala - 本地依赖由 SBT 解决,但不是由 Play 解决的!框架