以下两个有什么区别?
1#
trait B extends A {
}
Run Code Online (Sandbox Code Playgroud)
2#
trait B { self: A =>
}
Run Code Online (Sandbox Code Playgroud)
哪里A是抽象类.
>>编辑:
请解释以下Duck具有可插拔飞行和嘎嘎行为的s 示例:
abstract class Duck {
def fly(): Unit
def quack(): Unit
def swim() {
println("Woodoowoodoowoodoo...")
}
}
trait FlyingWithWings extends Duck {
override def fly() {
println("Me can fliez! :D")
}
}
trait FlyingNoWay { self: Duck =>
def fly() {
println("Me cannot fliez! :(")
}
}
trait Quack extends Duck {
override def quack() {
println("Quack! Quack!")
}
}
trait MuteQuack { self: Duck =>
def quack() {
println("<< Silence >>")
}
}
class MallardDuck extends Duck with FlyingWithWings with MuteQuack
object Main {
def main(args: Array[String]) {
val duck = new MallardDuck
duck.fly()
duck.quack()
}
}
Run Code Online (Sandbox Code Playgroud)
输出:
我可以飞!:D
<<沉默>>
在第二种情况下,B不能用于预期A的地方,它只是被设计为"附加"到某个A.所以例如在第一种情况下A可以是抽象的,B可以实现丢失的方法,使其成为可实例化的类型.这在第二种情况下是不可能的,您需要一个"完整的A",然后才会添加一些功能.
所以你可以想到一个"适合......"的关系,而不是"是......"的关系.