Scala相关知识学习总结4

1.抽象类:用 abstract 关键字定义,含抽象属性(声明无初始化)和抽象方法(无方法体),子类继承需实现抽象方法,可使用 super 关键字调用父类实现。

2. 匿名子类:类似Java,通过包含定义或重写代码块创建。

3. 单例对象:Scala无静态概念,单例对象可替代静态功能,用 object 声明,与类名一致时可伴生,成员可通过伴生对象名调用。

4. apply 方法:通过该方法可不使用 new 创建对象, apply 语句实际调用对应对象的 apply 方法。

5. 特质(trait)

  • 定义使用:可被混入类,实现类似接口功能,用 trait 声明,可定义属性、方法,可被类 extends 混入或与类 with 组合使用。

6.特质声明

基本语法

  • 基本语法:无父类时, class 类名 extends特质1 with 特质2... ;

有父类时, class 类名 extends 父类 with 特质1 with 特质2... 。

  • 说明:类与特质是继承关系,继承特质时首用 extends ,后续用 with ,同时继承父类和特质时,父类置于 extends 后。

  • (1)特质可含抽象与具体方法;(2)类可混入多个特质;(3)Java 接口可作Scala 特质; (4)动态混入可灵活的扩展类的功能,创建对象时混入 trait,而无需使类混入该 trait,如果混入的 trait 中有未实现的方法,则需要实现。

7. 特质叠加

  • 冲突类型及解决:类混入多个trait 时,若trait 有相同方法会产生继承冲突。

第一种是无关联trait 间冲突,在类中重写解决;

第二种是有继承关系的"钻石问题",采用特质叠加策略,即叠加冲突方法,通过示例展示叠加效果。

8.特质自身类型

  • 说明:可实现依赖注入功能。

  • 特质和抽象类的区别

(1) 类可方便混入多个特质,但只能扩展一个抽象类,优先用特质。

(2) 抽象类能定义带参数构造函数,必要时选用。

  • 冲突解决:多个trait方法冲突时,在类中重写解决。

  • 调用顺序:涉及 super 调用时,按混入顺序反向调用。

9.类型检查与转换:

  • 说明:obj.isInstanceOf[T] 判断对象是否为 T 类型,

obj.asInstanceOf[T] 将对象转换为 T 类型;

classOf 获取对象的类名。

10. 枚举:需继承 Enumeration ,通过 Value 定义枚举值。

11. 集合:包含序列( Seq )、集( Set )、映射( Map ),有可变与不可变版本,操作类似Java集合 。

12. 数组

  • 不可变数组:(1)new 是关键字

(2)[Int]是指定可以存放的数据类型,如果希望存放任意数据类型,则指定Any

(3)(10),表示数组的大小,确定后就不可以变化声明时指定大小或类型,可通过索引访问元素。

  • 可变数组:用 ArrayBuffer 实现添加、修改、删除元素操作,可与不可变数组转换。
相关推荐
武子康16 小时前
大数据-240 离线数仓 - 广告业务 Hive ADS 实战:DataX 将 HDFS 分区表导出到 MySQL
大数据·后端·apache hive
字节跳动数据平台2 天前
5000 字技术向拆解 | 火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
武子康2 天前
大数据-239 离线数仓 - 广告业务实战:Flume 导入日志到 HDFS,并完成 Hive ODS/DWD 分层加载
大数据·后端·apache hive
字节跳动数据平台3 天前
代码量减少 70%、GPU 利用率达 95%:火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
得物技术3 天前
深入剖析Spark UI界面:参数与界面详解|得物技术
大数据·后端·spark
武子康3 天前
大数据-238 离线数仓 - 广告业务 Hive分析实战:ADS 点击率、购买率与 Top100 排名避坑
大数据·后端·apache hive
武子康4 天前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
大大大大晴天4 天前
Flink生产问题排障-Kryo serializer scala extensions are not available
大数据·flink
武子康6 天前
大数据-236 离线数仓 - 会员指标验证、DataX 导出与广告业务 ODS/DWD/ADS 全流程
大数据·后端·apache hive
武子康7 天前
大数据-235 离线数仓 - 实战:Flume+HDFS+Hive 搭建 ODS/DWD/DWS/ADS 会员分析链路
大数据·后端·apache hive