Spark大数据处理讲课笔记1.7 掌握Scala类、对象、抽象类与特质

一、类
(一)类的定义
对象是类的具体实例,类是抽象的,不占用内存,而对象是具体的,占用存储空间。
面向对象三大特性之一:封装(encapsulation) - 封装数据和操作
Scala中一个简单的类定义是使用关键字class,类名首字母必须大写。类中的方法用关键字def定义

 二、单例对象
(一)单例对象概念
Scala中没有static关键字,当然也就没有静态方法或静态字段,但是可以使用关键字object定义一个单例对象,单例对象中的方法相当于Java中的静态方法,可以直接使用“单例对象名.方法名”方式进行调用。单例对象除了没有构造器参数外,可以拥有类的所有特性。

 在net.huawei.day04包里创建TestPerson对象

 

三、伴生对象
(一)伴生对象概念
当单例对象的名称与某个类的名称一样时,该对象被称为这个类的伴生对象。类被称为该对象的伴生类。类和它的伴生对象必须定义在同一个文件中,且两者可以互相访问其私有成员。
(二)案例演示
在net.huawei.day04包里,创建Scala类Student,在文件里创建其伴生对象Student

四、get和set方法
(一)生成原则
Scala默认会根据类的属性的修饰符生成不同的get和set方法
1、val修饰的属性 - 公共常量属性
系统会自动生成一个公共常量属性和一个公有get方法。
2、var修饰的属性 - 公共变量属性
系统会自动生成一个公共变量属性和一对公有get/set方法。
3、private var修饰的属性 - 私有变量属性
系统会自动生成一对私有get/set方法,相当于类的私有属性,只能在类的内部和伴生对象中使用。
4、private[this]修饰的属性 - 本地私有变量属性
系统不会生成get/set方法,即只能在类的内部使用该属性。

(二)案例演示

任务1、利用系统自动生成的get和set方法

(1)创建Dog类

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值