8.Scala面向对象开发-2

8.1 对象

  • 单例对象
  • 伴生对象
  • 扩展类和特质
    • 构造一个扩展了指定类和特质的类的对象,同时拥有对象定义中给出的所有特性
  • apply方法

8.1.1 单例对象

  • object语法定义了某个类的单个实例
  • 对象的构造器在该对象第一次被使用时调用
  • object语法结构与class大致相同,除了object不能提供构造器参数
  • 通常使用单例对象的环境:
    • 作为存放工具函数或常量的地方
    • 共享单个不可变实例
    • 利用单个实例协调某个服务


8.1.2 伴生对象

  • 当一个单例对象存在同名类的时候,称为伴生对象
    • class HELLOWORLD{...}
    • objectHELLOWORLD{...}
  • 类和其伴生对象可以互相访问私有属性,但必须存在同一个源文件中
  • 类的伴生对象可以被访问,但并不在作用域中,如;
    • class HELLOWORLD{...}
    • object HELLOWORLD{ def NOW{...} }
  • HELLOWORLD 类必须通过HELLOWORLD.NOW调用伴生对象中的NOW方法,而不能直接用NOW来调用

8.1.3 Apply方法

  • 需要构造有参数需求的伴生对象时,可定义并使用apply方法
class HELLOWORLD(var m:String,n:Char){...}
object HELLOWORLD{
def apply(n:Char)=new HELLOWORLD("",n) 
} 

val hi=HELLOWORLD('j')

8.2 继承-1

  • 拓展
  • 重写
  • 抽象

8.2.1 拓展

  • extends是Scala中实现继承的保留字
  • class week extends month{...}
    • week类继承了month类所有非私有成员
    • week类是month类的子类,month类是week类的超类
    • 子类能重写超类的成员(具有相同名称和参数)
  • class week(val num:Int) extendsmonth(var no.:Int){...}
  • object day extendsweek{...}
    • 单例对象同样能从类中继承,与类的继承语法相同

8.2.2 重写

  • Scala中使用override保留字进行方法、字段重写
    • class week extends month{
    • override def firstday = {...}
    • }
  • override保留字实际使用类似于private,声明这个保留字后的定义、声明是对超类的重写,因此,其也可以写在类定义的参数中
    • class week(override val lastday:String)extends month{...}
  • 子类的重写或修改Scala会检查其超类,但是,超类的修改并不会检查其子类
  • 重写包括字段和方法,但参数不同的方法可以不重写
    • class month{ def secondday(m:String)={...}}
    • class week extends month{ def secondday ={...}}

8.2.2.1 重写规则

  • 重写def
    • 用val :利用val能重写超类用没有参数的方法(getter)
    • 用def:子类的方法与超类方法重名
    • 用var:同时重写getter、setter方法,只重写getter方法报错
  • 重写val
    • 用val:子类的一个私有字段与超类的字段重名,getter方法重写超类的getter方法
  • 重写var
    • 用var:且当超类的var是抽象的才能被重写,否则超类的var都会被继承

8.2.2.2 重写示例

  • class month{
  • val one = 25 //可在子类中用val重写
  • var two = 15 //不可在子类中用var重写,因为不是抽象的
  • var three:Int
  • def firstday = //可在子类中用val重写
  • def now = //可在子类中用var重写
  • def now_ =
  • def lastday(m:Char)={} //可在子类中用def重写
  • }
  • 子类中,def只能重写超类的def,val能重写超类的val或不带参数的def,var只能重写超类中抽象的var或者超类的getter/setter对

8.2.3 抽象

  • 不能被实例化的类叫做抽象类
  • 抽象类的某个或某几个成员没有被完整定义,这些没有被完整定义的成员称为抽象方法或抽象字段
  • 用abstract保留字标记抽象类
    • abstractyear{
    • val name:Array[String] //抽象的val,带有一个抽象的getter方法
    • var num:Int //抽象的var,带有抽象的getter/setter方法
    • def sign//没有方法体/函数体,是一个抽象方法
    • }
  • 只要类中有任意一个抽象成员,必须使用abstract标记
  • 重写抽象方法、抽象字段不需要使用override保留字
    大数据视频推荐:
    腾讯课堂
    CSDN
    大数据语音推荐:
    企业级大数据技术应用
    大数据机器学习案例之推荐系统
    自然语言处理
    大数据基础
    人工智能:深度学习入门到精通

你可能感兴趣的:(8.Scala面向对象开发-2)