Spark犹如一座巨山,压倒在我的面前
特质
- 如果特质中只有抽象内容,这样的特质就做瘦接口
- 如果特质中既有抽象内容,又有具体内容,这样的特质叫:富接口
特质的格式
trait 特质名称{
//普通字段
//抽象字段
//普通方法
//抽象方法 }
特质可以继承
class 类 extends 特质1 with 特质2{
//重写抽象方法
//重写抽象字段 }
scala中不管是类还是特质,继承的时候都用extends来继承
如果要继承多个特质,那么特质名之间需要使用with
类继承单个特质
特质里面有抽象方法和具体方法。
在继承特质的时候要重写方法
类继承多个特质
在继承多个特质的时候,在特质于特质之间要使用with
单例对象继承特质
单例对象也就是全局对象,不能被创建。全局唯一。
当单例对象继承特质后,直接 单例对象.方法
trait 特质名{ } object 单例对象名 extends 特质名{
//重写方法 }
从上面的图中,可以看到,在特质里面具体的方法名可以不用被重写,子类调用特质里面具体的方法是可以直接调用的。
对象掺杂特质
如果不希望改变类的继承体系,又想让类具有某些方法,可以使用
new 对象 with 特质
Trait的构造机制
- 遇到一个类继承另一个类、以及多个trait的情况,当创建该类的实例时,它的构造器执行顺序如下:
1. 执行父类的构造器
2. 按照`从左到右`的顺序, 依次执行trait的构造器
3. 如果trait有父trait,则先执行父trait的构造器.
4. 如果多个trait有同样的父trait,则父trait的构造器只初始化一次.
5. 执行子类构造器
按照上面的执行顺序,那么上面这段代码的执行顺序应该是
- Person的构造器
- Logger构造器
- TimeLogger构造器
- MyLogger构造器
- student构造器
总结:
scala中的内容,会每天发布一篇博客,同时,也会慢慢同步Spark的学习博客