【发布时间】:2015-06-19 09:59:52
【问题描述】:
我对如何在不作弊和使用asInstanceOf 的情况下完成以下任务持空白。
假设我有一些任意密封类型的对象,每个对象都有自己的类型成员。
sealed trait Part { type A }
case object P1 extends Part { override type A = String }
case object P2 extends Part { override type A = Int }
现在说我将一个 P 和一个 P.A 值捆绑在一起......
trait PartAndA {
val p: Part
val a: p.A
}
object PartAndA {
type Aux[P <: Part] = PartAndA {val p: P}
def apply(_p: Part)(_a: _p.A): Aux[_p.type] =
new PartAndA {
override val p: _p.type = _p
override val a = _a
}
}
如何在没有手动强制转换的情况下安全地完成以下任务?
def fold[A](pa: PartAndA)(p1: PartAndA.Aux[P1.type] => A,
p2: PartAndA.Aux[P2.type] => A): A =
pa.p match {
case P1 => p1(pa.asInstanceOf[PartAndA.Aux[P1.type]])
case P2 => p2(pa.asInstanceOf[PartAndA.Aux[P2.type]])
}
【问题讨论】:
标签: scala scala-2.11