在Java中实现Scala PartialFunction的最简单方法是什么?



为了互操作性,我需要从Java代码传递一个Scala PartialFunction。对于函数(函数 1 等(,我可以用匿名类型子类 AbstractFunction,但是对于 PartialFunction 做同样事情的最简单方法是什么?

在这种情况下,我很乐意让它成为 Java 中的"完整"函数,为所有值定义,但类型为 PartFunction。

我在这里要做的是用Java提供接口,在一些公共库中(不是scala感知的(:

//this is Java - in the Java lib
abstract class PartialTransformer<I, O> {
    abstract public boolean isDefinedAt(I i);
    public O transform(I i) {
        if (isDefinedAt(i)) {
            return transform0(i);
        }
        return null;
    }
    abstract protected O transform0(I i);
}

然后,在scala(即依赖于上述Java库的scala库(中,将其实现转换为PartialFunction

//this is scala - in the scala lib
object MyPartialFunctions {
  def fromPartialTransformer[I, O](t: PartialTransformer[I, O]) = new PartialFunction[I, O] {
    def isDefinedAt(i: I) = t isDefinedAt i
    def apply(i: I) = {
      val r = t transform i
      if (r eq null) throw new MatchError
      else r
    }
  }
}

然后你的 Java 代码可以做到这一点:

//This is Java - in your client code
MyPartialFunctions$.MODULE$.fromPartialTransformer(new PartialTransformer<Integer, String>() {
    @Override public boolean isDefinedAt(Integer i) { /* */ }
    @Override protected String transform0(Integer i) { /* */ }
}

如果你不喜欢MyPartialFunctions$.MODULE$语法,可以在scala库中使用,这是一个Java类,它对你隐藏了这一点:

//This is Java - in the scala-lib
public class ScalaUtils {
    public <I, O> scala.PartialFunction<I, O> toPartialFunction(PartialTransformer<I, O> t) {
         MyPartialFunctions$.MODULE$.fromPartialTransformer(t);
    }
}

然后你的呼叫站点看起来像这样:

//This is Java - in your client code
ScalaUtils.toPartialFunction(new PartialTransformer<Integer, String>() {
    @Override public boolean isDefinedAt(Integer i) { /* */ }
    @Override protected String transform0(Integer i) { /* */ }
}

这涉及到,咳咳,几个级别的间接!

如果你可以使用 Twitter Util 库,它有一个专门用于此的类:http://twitter.github.com/util/util-core/target/site/doc/main/api/com/twitter/util/Function.html 它与 AbstractPartialFunction 的解决方案基本相同。

作为 Chris 答案的补充,在 Scala 2.10 中你可以使用这个: http://www.scala-lang.org/archives/downloads/distrib/files/nightly/docs/library/scala/runtime/AbstractPartialFunction.html

相关内容

  • 没有找到相关文章

最新更新