快学Scala系列(特质)

Spark犹如一座巨山,压倒在我的面前

特质

  1. 如果特质中只有抽象内容,这样的特质就做瘦接口
  2. 如果特质中既有抽象内容,又有具体内容,这样的特质叫:富接口

特质的格式

       

 trait 特质名称{
 //普通字段
 //抽象字段 
//普通方法
 //抽象方法 }

        特质可以继承

class 类 extends 特质1 with 特质2{ 
//重写抽象方法 
//重写抽象字段 }

        scala中不管是类还是特质,继承的时候都用extends来继承

        如果要继承多个特质,那么特质名之间需要使用with

类继承单个特质

        特质里面有抽象方法和具体方法。

        在继承特质的时候要重写方法

快学Scala系列(特质)

 

类继承多个特质

快学Scala系列(特质)

 

        在继承多个特质的时候,在特质于特质之间要使用with

单例对象继承特质

        单例对象也就是全局对象,不能被创建。全局唯一。

        当单例对象继承特质后,直接 单例对象.方法

trait 特质名{ } object 单例对象名 extends 特质名{
 //重写方法 }

快学Scala系列(特质)

快学Scala系列(特质)

        从上面的图中,可以看到,在特质里面具体的方法名可以不用被重写,子类调用特质里面具体的方法是可以直接调用的。

对象掺杂特质

        如果不希望改变类的继承体系,又想让类具有某些方法,可以使用

new 对象 with 特质

快学Scala系列(特质)

 

Trait的构造机制

- 遇到一个类继承另一个类、以及多个trait的情况,当创建该类的实例时,它的构造器执行顺序如下:

1. 执行父类的构造器

2. 按照`从左到右`的顺序, 依次执行trait的构造器

3. 如果trait有父trait,则先执行父trait的构造器.

4. 如果多个trait有同样的父trait,则父trait的构造器只初始化一次.

5. 执行子类构造器

快学Scala系列(特质)

 

按照上面的执行顺序,那么上面这段代码的执行顺序应该是

  1. Person的构造器
  2. Logger构造器
  3. TimeLogger构造器
  4. MyLogger构造器
  5. student构造器

总结:

        scala中的内容,会每天发布一篇博客,同时,也会慢慢同步Spark的学习博客

上一篇:Scala 处理null不规范 导致 编译失败


下一篇:任何JVM项目中使用(前提是添加Scala