编写一个返回=>的函数Ť

时间:2015-01-05 09:47:08

标签: scala

我试图编写一个简单的转换器,将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函数?

1 个答案:

答案 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​​。它只会在需要时执行,因此在许多方面都会像传递函数一样。