我试图编写一个简单的转换器,将java.util.Function
转换为scala.Function1
:
def toScalaProducer[T](f: JavaFunction0[T]) : => T = => f()
这是另一种运作良好的变体:
def toScalaFunction[T](f: JavaFunction0[T]) : () => T =
() => f.apply()
问题是我想将转换后的函数传递给现有的Scala API,但that API只接受=> T
类型的参数,而不是() => T
类型的参数。
有没有办法编写toScalaProducer
函数?
答案 0 :(得分:6)
() => T
是一个函数的类型,它不带任何参数并返回T
类型的东西
=> T
是延迟评估的值T
的类型。例如:
def myFunc(t: => Int): Unit = {
// Do something with t
}
myFunc(reallyExpensiveFunctionProducingAnInt())
此处,reallyExpensiveFunctionProducingAnInt
可能需要很长时间才能运行,但只有在t
中使用值myFunc
时才会执行。如果您只使用Int
类型代替=> Int
,则会在输入myFunc
之前调用它。
请点击此处了解详情:Scala's lazy arguments: How do they work?
因此,如果您的toScalaProducer
函数只是执行了Java函数并且返回值为T
,那么它应该可以正常使用API。它只会在需要时执行,因此在许多方面都会像传递函数一样。