为什么我不能将Scala的Function1隐式转换为java.util.function.Function?

我正在尝试创建Scala的Function1到java.util.function.Function的隐式转换。

这是我的代码:

object Java8ToScala extends App { implicit def javaFuncToScalaFunc[T, R](func1: Function[T, R]): function.Function[T,R] = { new function.Function[T, R] { override def apply(t: T): R = func1.apply(t) } } val javaFunc:function.Function[String,Int] = (s:String) => s.length println(javaFunc.apply("foo")) // this works private val strings = new util.ArrayList[String]() println(strings.stream().map(javaFunc).collect(Collectors.toList())) // this doesn't work } 

编译器消息很难理解:

 [error] /xxx/Java8ToScala.scala:74: no type parameters for method map: (x$1: java.util.function.Function[_ >: String, _ : String, _ <: ?R] [error] Note: String <: Any, but Java-defined trait Function is invariant in type T. [error] You may wish to investigate a wildcard type such as `_ : String, _ <: R] [error] .map(javaFunc).collect(Collectors.toList())) [error] ^ [error] two errors found [error] (compile:compileIncremental) Compilation failed [error] Total time: 7 s, completed Dec 18, 2015 10:51:15 AM 

它只是Scala类型推断失败,虽然我不明白为什么:它似乎正在寻找扩展AnyRef 如果使用这样的类型,它可以工作 ,例如val javaFunc: function.Function[String,String] = (s:String) => s

但是,它没有在任何地方获得上限:使用map[Int]明确地起作用 。

使用以下隐式转换:

 implicit def javaFuncToScalaFunc[T, R](func1: function.Function[T, R]): Function[T,R] = { new Function[T, R] { override def apply(t: T): R = func1.apply(t) } } 

在您的代码中,您有一个从Scala函数到Java函数的隐式转换,但您应该从Java函数到Scala函数进行隐式转换。