在这个Java类中:
import java.util.function.*;
public class T {
public String func(String a) {
System.out.println("There we go: " + a);
return a;
}
public static void main(String... args) {
final Supplier
有没有办法在scala中做同样的事情,即得到
val c: () => T = ??? // default constructor of T as function
val f: (T,String) => String = ??? // instance method func of T as function
没有包装它们:
val c: () => T = () => new T
val f: (T,String) => String = (t,arg) => t.func(arg)
最佳答案
首先,让我们看一下Scala的Java代码的字面翻译:
class T {
def func(a:String) : String = {
println(s"There we go: $a")
a
}
}
object T {
def main(args: Array[String]) = {
val supplier = () => new T
val f = (t:T) => t.func _
val t = supplier()
val v = f(t)("something")
println(v)
}
}
在Scala中,函数是一等公民,因此没有必要为“生成的东西”(如Java供应商)设置特定的结构,因为它被建模为函数:f:()=> T(对应的是同行,消费者为f:T =>())
我们刚才说函数是一等公民,所以让我们看看上面使用这个范例的版本:
object Tfunc {
// let's remove the println side-effect from a function.
val func: String => String = a => s"There we go: $a"
def main(args: Array[String]) = {
println(func("something"))
}
}
在Scala中,没有获得构造函数引用的对应物,但如果目标是使用函数方法,则Scala对象提供一个简单的构造来保存函数,而不需要实例化.