一、 将trait做为接口使用设计模式
二、trait中定义具体方法ide
三、trait定义具体字段函数
四、trait中定义抽象字段工具
五、为实例对象混入traitspa
六、trait调用链scala
七、在trait中覆盖抽象方法设计
八、混合使用trait的具体方法和抽象方法3d
九、trait的构造机制日志
十、trait field的初始化对象
十一、trait继承class
在scala中,trait是一种特殊的概念,能够将trait做为接口来使用。
Trait能够定义抽象方法,与抽象类中的抽象方法同样,只要不给出方法的具体实现便可。
类可使用extends关键字继承trait,sclaa中没有implement的概念,不管继承仍是trait。
类继承trait后,必须实现其中的抽象方法,实现时不须要使用override关键字。
Scala不支持对类进行多继承,可是支持多继承trait,使用with关键字便可。
Trait不是只定义抽象方法,还能够定义具体方法,此时trait更像是包含了通用工具的方法。
有一个专有名词来形容这种状况,就是说trait的功能混入了类。
Trait中能够包含一些不少类都通用的功能方法,好比打印日志等等。
Trait能够定义具体field,此时继承trait的类就自动得到了trait中定义的field。
这种获取field的方式与继承class是不一样的,若是是继承class获取的field,其实是定义在父类中的,而继承trait获取的field,就直接被添加到了类中。
Trait能够定义抽象field,而trait中的具体方法则能够基于抽象field来编写。
继承trait的类,必须覆盖抽象field,并提供具体的值。
有时候咱们建立类的时候,指定该对象混入某个trait,这样就只有这个对象混入该trait的方法,而类的其余对象则没有。
Scala中支持让类继承多个trait,依次调用多个trait中的同一个方法,只要让多个trait的同一个方法中,在最后都执行supper方法便可。
类中调用多个trait中都有的这个方法时,首先会从最右边的trait的方法开始执行,依次往左执行,造成一个调用链条。
这种特性很是强大,其实就至关于设计模式中的责任链模式的一种具体实现依赖。
Trait中,能够覆盖父trait的抽象方法。覆盖时,若是使用了super.方法的代码,则没法经过编译。由于super.方法就会去掉用父trait的抽象方法,此时子trait的该方法仍是会被认为是抽象的。若是要经过编译,就得给trait的方法加上abstract override修饰。
在trait中,能够混合使用具体方法和抽象方法,可让具体方法依赖于抽象方法,而抽象方法则放在继承trait的类中去实现。
这种trait其实就是设计模式中的模板设计模式的体现。
Trait有构造函数,就是不包含任何方法中的代码。
而继承了trait的类的构造机制以下:
一、 父类的构造函数执行
二、 Trait的构造代码执行,多个trait从左到右依次执行
三、 构造trait时会先构造父trait,若是多个trait继承同一个父trait,则父trait只会构造一次。
四、 全部trait构造完毕后,子类的构造函数执行。
Scala中,trait没有接受参数的构造函数,若是需求就是要trait能对field进行初始化,只能使用scala中很是特殊的一种高级特性,即提早定义。
两种提早定义
另一种方式就是使用lazy value
Scala中,trait能够继承自class,此时这个class就会成为全部继承该trait的类的父类。