在
Scala中,我们使用这样的混合:
class C extends A with B
我理解这个声明,因为C是A和B的子类.这是真的吗?或者C只是A和B的子类(我不认为JVM上不支持多继承)?
如果A与B是一个类型,为什么这条线不起作用?
classOf[A with B]
我认为A与B类型的另一个原因是它可以用于模式匹配:
val c = new C val u = c match { case a: A with B => 1 } // 1
解决方法
Scala通过特征支持多重继承.任何类都可以扩展0或1类,但也可以“混合”任意数量的特征. (有一些编译器魔法重新排列幕后的东西以符合JVM的限制)语法是沿着
class MyClass extends [ClassOrTrait] with [Trait] with [AnotherTrait] with ...
所以你的C类定义更像
class((C扩展A)与B)比类似(C扩展(A与B))
A与B是一种类型,可以用作类型别名,但classOf方法需要一个类:
scala> type AB = A with B defined type alias AB scala> classOf[AB] <console>:11: error: class type required but A with B found classOf[AB] ^
VS
scala> class AB extends A with B defined class AB scala> classOf[AB] res12: Class[AB] = class AB