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 可以遍历枚举值

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值