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 实现添加、修改、删除元素操作,可与不可变数组转换。
相关推荐
潘达斯奈基~1 小时前
在使用spark的applyInPandas方法过程中,遇到类型冲突问题如何解决
大数据·笔记
火星资讯2 小时前
腾多多数字零售模式:从成本转嫁到全生态共赢的破局实践
大数据
望获linux3 小时前
【实时Linux实战系列】实时 Linux 的自动化基准测试框架
java·大数据·linux·运维·网络·elasticsearch·搜索引擎
金宗汉3 小时前
《宇宙递归拓扑学:基于自指性与拓扑流形的无限逼近模型》
大数据·人工智能·笔记·算法·观察者模式
直有两条腿4 小时前
【数据迁移】HBase Bulkload批量加载原理
大数据·数据库·hbase
Joy T4 小时前
海南蓝碳:生态财富与科技驱动的新未来
大数据·人工智能·红树林·海南省·生态区建设
风清再凯4 小时前
01-ELK安装ES,ES-head
大数据·elk·elasticsearch
Guheyunyi5 小时前
风险感知中枢:监测预警系统的架构与核心
大数据·运维·安全·重构·架构·自动化
正在走向自律5 小时前
大数据背景下时序数据库选型指南:国产开源技术的突破与实践
大数据·开源·时序数据库
shinelord明6 小时前
【大数据技术实战】Kafka 认证机制全解析
大数据·数据结构·分布式·架构·kafka