我正在尝试编写一个简单的转换器,将a java.util.Function转换为scala.Function1:
def toScalaProducer[T](f: JavaFunction0[T]) : => T = => f()
Run Code Online (Sandbox Code Playgroud)
这是另一个效果很好的变体:
def toScalaFunction[T](f: JavaFunction0[T]) : () => T =
() => f.apply()
Run Code Online (Sandbox Code Playgroud)
问题是我想将转换后的函数传递给现有的Scala API,但该API只接受类型的参数=> T,而不是类型的参数() => T.
有没有办法写这个toScalaProducer功能?
() => T 是一个函数的类型,它不带任何参数并返回类型的东西 T
=> T是一个T懒惰评估的值的类型.例如:
def myFunc(t: => Int): Unit = {
// Do something with t
}
myFunc(reallyExpensiveFunctionProducingAnInt())
Run Code Online (Sandbox Code Playgroud)
在这里,reallyExpensiveFunctionProducingAnInt可能需要很长的时间来运行,但如果该值将只执行t中使用myFunc.如果您只是使用类型Int而不是=> Int它将在myFunc输入之前被调用.
在这里查看更多信息:Scala的懒惰论点:它们如何工作?
因此,如果您的toScalaProducer函数只是执行了Java函数并且返回值为T,那么它应该可以正常使用API.它只会在需要时执行,因此在很多方面都会像传递函数一样.
| 归档时间: |
|
| 查看次数: |
97 次 |
| 最近记录: |