(在Scala中)是否可以使用类的泛型类型参数而不是抽象类型成员来完成任何操作?

时间:2014-10-07 10:02:07

标签: scala generics types parameters abstract

很明显,无法使用抽象类型成员参数化方法。但是,是否有任何理由存在类的泛型类型参数,除了类型和实例化可以写得更短的便利问题,例如在以下抽象的List-ArrayList场景中:

这里,参数化由抽象类型成员实现:

trait base1 {
    type X
    def id(x: X): X
}
class extension1 extends base1 {
    override def id(x: X): X = x
}
val ext1: base1 { type X = Int } = new extension1 { type X = Int }
val y1 = ext1.id(0)

这里通过泛型类型参数来实现:

trait base2[X] {
    def id(x: X): X
}
class extension2[X] extends base2[X] {
    override def id(x: X): X = x
}
val ext2: base2[Int] = new extension2[Int]
val y2 = ext2.id(0)

后一种解决方案更方便,更易读。这本身很重要,但我对更一般的,即语义的观点感兴趣。

This采访Martin Odersky是一个很好的介绍,但它似乎没有回答这个问题。

非常感谢您的任何提示或解释!

1 个答案:

答案 0 :(得分:4)

Dean Wampler和Alex Payne撰写的 Programming Scala 一书给出了关于何时使用类型参数与抽象类型成员的好overview

除了不能参数化方法(这可能是一个很大的限制)之外,抽象类型成员有两个限制:

  1. 抽象类型不能进行方差注释(参见p. 269)含义与trait List[+T]trait Function[-T,+R]等效的抽象类型成员。

  2. 抽象类型可能导致具有路径依赖类型的不合理类型错误。 p. 272上有一个例子。