trait
- trait的变量并不能直接访问,说明不是静态的.
- trait既能被class继承也能被object继承
- 每一个继承trait的类生成实例的时候(无论是class还是object)都换先生成一个trait实例(或者说对象)
- java的属性是static final的,全局唯一。而trait的属性实际上是方法调用而已。
class Son()
trait Father {
println("i am trait")
val son = new Son()
var b = new Son()
}
class Child1 extends Father
class Child2 extends Father
object Child3 extends Father
object Child4 extends Father
对于上面的代码,如果Child1和Child2的实例的son(不能是case class,因为case 自己实现了hashCode)属性相等.那说明他们指向同一个Father实例,反之则不是。下面的代码输出都是false,说明无论object还是class在生成对象的时候,father trait都是单独生成了一个实例。
object Context {
def main(args: Array[String]): Unit = {
// println(Father.a) // error trait的变量并不能直接访问,说明不是静态的。
val child1 = new Child1
val child2 = new Child2
println(child1.son == child2.son) // false
println(Child3.son == Child4.son)// false
}
}
抽象类
在scala中接口和抽象类在内存中没什么区别。
- 抽象类的变量并不能直接访问,说明不是静态的.
- 抽象类既能被class继承也能被object继承
- 每一个继承抽象类的类生成实例的时候(无论是class还是object)都换先生成一个抽象类实例(或者说对象)
- 唯一的区别:trait多继承,抽象类是单继承
object
- object是全局唯一的,换句话说是单例的
- object的方法和属性都是静态的
- object不可被继承,反编译的结果是final类
- object不支持泛型