Spark学习(9)——scala面向对象编程(对象)

object

Object,相当于class的单个实例,通常在里面放一些静态的field或者method,第一次调用object方法时,就会执行objectconstructor,也就是object内部不在method的代码,但是object不能定义接收参数的constructor,注意,objectconstructor只会在其第一次被调用时执行一次,以后再次调用就不会再次执行constructor了,object通常用于作为单例模式的实例,或者放class的静态成员,比如工具方法

伴生对象

如果有一个class,还有一个与class同名的object,那么就称这个objectclass的伴生

对象,classobject的伴生类,伴生类和伴生对象必须存放在一个.scala文件之中

伴生类和伴生对象,最大的特点就在于,互相可以访问private  field

让object继承抽象类

Object的功能其实和class类似,除了不能定义接受参数的constructor之外,

Object也可以继承抽象类,并覆盖抽象类中的方法

apply方法

Object中非常重要的一个特殊方法,就是apply方法

通常在伴生对象中实现apply方法,并在其中实现构造伴生类的对象的功能,而创建伴生类的对象时,

通常不会使用new Class的方式,而是使用Class()的方式,隐式的调用伴生对象的apply的方法,这样会让对象创建更加简洁

比如,Array类的伴生对象的apply方法就实现了接收可变数量的参数,并创建一个Array对象的功能

Val a =Array(1,2,,3,4,5)

比如,定义自己的伴生类和伴生对象

main方法

就如同Java中,如果要运行一个程序,必须编写一个包含main方法类一样,在scala中,如果要运行一个应用程序,那么必须有一个main方法,作为入口

Scala中的main方法定义为def  main(args: Array[String]),而且必须定义在object

object HelloWorld{

def main(args: Array[String]){

println("hello world")

}

}

将上述代码放到一个scala的文件中,在命令行用scalac  HelloWorld.scala编译,scala HelloWorld  运行

运行结果

除了自己实现main方法之外,还可以继承App Trait,然后将需要在main方法中运行的代码直接作为objectconstructor代码,而且用args可以接受传入的参数

object HelloApp extends App{
  if(args.length >0) println("hello:" +args(0))
  else println("hello App")
}

用object来实现枚举功能

Scala没有直接提供类似于Java中的Enum这样的枚举特性,如果要实现枚举,则需要用object继承Enjumeration类,并且调用value方法来初始化枚举值

还可以通过Value传入枚举值的idname,通过idtoString可以获取,还可以通过idname来查找枚举值

使用枚举object.values 可以遍历枚举值