我正在使用一个具有密封特征的库。 我真的需要扩展这个特质。
有没有一种方法(即使是一种肮脏的方法)来绕过它?
对于一些背景知识,这就是我正在尝试解决的问题:https://github.com/ReactiveMongo/ReactiveMongo/issues/247
最佳答案
如果您需要考虑其他选择,请不要扩展,包括。
// Foo.scala
sealed trait Foo
case class Foo1(n: Int) extends Foo
case class Foo2(s: String) extends Foo
// Bar.scala
sealed trait Bar
case class BarFoo(foo: Foo) extends Bar
case class Bar3(b: Boolean) extends Bar
并且可以通过隐式转换来减少样板
implicit def fooToBar(foo: Foo): Bar = BarFoo(foo)
<小时/>
或者如果您想向现有类添加新方法,请使用隐式类:
// Foo.scala
sealed trait Foo
case class Foo1(n: Int) extends Foo
case class Foo2(s: String) extends Foo
// Quux.scala
// This class be called FooOps or FooExtra, if you like, name is irrelevant
implicit class Quux(foo: Foo) {
def quux: Boolean = foo match {
case Foo1(n) => n == 0
case Foo2(s) => s.isEmpty
}
}
然后您可以在 Foo
值上使用 .quux
:
scala> Foo1(2).quux
res1: Boolean = false
scala> Foo2("").quux
res2: Boolean = true
这与扩展大致相同,但样板代码更少,比较:
case class Quux2(foo: Foo) {
def quux2: Boolean = foo match {
case Foo1(n) => n == 0
case Foo2(s) => s.isEmpty
}
}
implicit def fooToQuux2(foo: Foo): Quux2 = Quux2(foo)
scala> Foo1(2).quux
res0: Boolean = false
scala> Foo2("").quux
res1: Boolean = true
关于scala - 重写 Scala 中的密封特征,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27937731/