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
是按名称调用的参数。这意味着 f
是 T
类型,传递给函数的表达式将在使用时计算(而不是在调用函数时计算。
String => T
类型表示 f
是一个 Function[String,T]
,即 function[String,T]
中的函数 String
到 T
。
当你调用 "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***
因为您现在正确地将函数、g
从String
传递给某些T
。这里的 T
是 String
,因为该函数只是将 ***
添加到传递的任何内容的末尾并返回修改后的字符串。
关于Scala的函数作为参数的用法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10696704/