我有三F-绑定类型A
,B
& C
,其中B
由A
参数化的,并且C
由B
参数化(并因此也通过A
)。我可以实例化A
和B
,但是当我尝试实例化C
时,编译器无法推断出这些类型。如果我明确地给出它的类型,一切都可行 - 但这些类型丢失似乎相当愚蠢(这是由于类型擦除?)。构建三级深F-绑定类型
sealed trait A[AA <: A[AA]] {
self =>
val data: String
}
case class AInst(data: String) extends A[AInst]
sealed trait B[BB <: B[BB, AA], AA <: A[AA]] {
self: BB =>
val content: AA
}
case class BInst[AA <: A[AA]](content: AA) extends B[BInst[AA], AA]
sealed trait C[CC <: C[CC, BB, AA], BB <: B[BB, AA], AA <: A[AA]] {
self: CC =>
val content: BB
}
case class CInst[BB <: B[BB, AA], AA <: A[AA]](content: BB)
extends C[CInst[BB, AA], BB, AA]
val a1 = new AInst("A1")
val b1 = BInst(a1)
val c1 = CInst[BInst[AInst],AInst](b1)
有一个变通,在那里我没有为CInst
专门指定的类型?
我目前使用类型参数化来实现F-Bounds,但是会切换到抽象类型成员来解决这个问题吗?上课怎么样?
我在这里的例子:https://stackoverflow.com/questions/1154571/scala-abstract-types-vs-generics/10891994#10891994 – ayvango