Spark大数据分析与实战笔记(第一章 Scala语言基础-4)

文章目录

  • 每日一句正能量
  • [1.4 Scala面向对象的特性](#1.4 Scala面向对象的特性)
    • [1.4.1 类与对象的特性](#1.4.1 类与对象的特性)
    • [1.4.2 继承](#1.4.2 继承)
    • [1.4.3 单例对象和伴生对象](#1.4.3 单例对象和伴生对象)
    • [1.4.4 特质](#1.4.4 特质)

每日一句正能量

若要快乐,就要随和;若要幸福,就要随缘。快乐是心的愉悦,幸福是心的满足。别和他人争吵,别和命运争吵,无计较之心,心常愉悦;尽心之余,随缘起止,随遇而安,心常满足。你随和,愉悦的是自己的心,别人计较,苦闷的是他自己。一天的心情靠随和,一生的幸福靠随缘。

1.4 Scala面向对象的特性

无论是在Scala中还是Java中,类都是对象的抽象,而对象都是类的具体实例;类不占用内存,而对象占用存储空间。由于面向对象的核心是对象,若想要在应用程序中使用对象,就必须得先创建一个类。类是用于描述一组对象的共同特征和行为。

1.4.1 类与对象的特性

创建类的语法格式如下:

复制代码
class 类名[参数列表] 

当类创建好之后,若是想要访问类中的方法和字段,就需要创建一个对象。

创建对象的语法格式如下:

复制代码
类名 对象名称 = new 类名(); 

下面创建一个Point类,并在类中定义两个字段x和y以及一个没有返回值的move( )方法,使Point类的实例对象来访问类中的方法和字段,代码如下所示:

scala 复制代码
package cn.itcast.scala
//定义类
class Point(xc:Int,yc:Int){
//定义字段
  var x:Int = xc
  var y:Int = yc

  //定义方法
  def move(dx:Int,dy:Int):Unit = {
    x = x + dx
    y = y + dy
    println("x的坐标点:"+x)
    println("y的坐标点:"+y)
  }
}
object Ch07_ClassTest {
  def main(args: Array[String]): Unit = {
    //定义类对象
    val pt = new Point(10,20)

    //移动到一个新的位置
    pt.move(10,10)
  }
}

1.4.2 继承

  • Scala和Java类似,只允许继承一个父类。
  • Java只能继承父类中非私有的属性和方法,而Scala可以继承父类中的所有属性和方法。

在Scala子类继承父类的时候,有以下几点需要注意

  • 如果子类要重写一个父类中的非抽象方法,则必须使用override关键字,否则会出现语法错误。
  • 如果子类要重写父类中抽象方法时,则无需使用override关键字
    下面,创建一个Point类和Location类,并且Location类继承Point类,演示子类Location重写父类Point中的字段,具体代码如下所示:
scala 复制代码
package cn.itcast.scala
//定义父类:Point类
class Point2(val xc:Int,val yc:Int){
  //定义字段
  var x:Int = xc
  var y:Int = yc

  //定义方法
  def move(dx:Int,dy:Int):Unit = {
    x = x + dx
    y = y + dy
    println("x的坐标点:"+x)
    println("y的坐标点:"+y)
  }
}

//定义子类:Location类继承Point类
class Location(override val xc:Int,override val yc:Int,zc:Int) extends Point2 (xc,yc){
  var z:Int = zc
  def move(dx:Int,dy:Int,dz:Int): Unit ={
    x = x + dx
    y = y + dy
    z = z + dz
    println("x的坐标点:"+x)
    println("y的坐标点:"+y)
    println("z的坐标点:"+z)
  }
}

object Ch08_ExtendsTest {
  def main(args: Array[String]): Unit = {
    var loc = new Location(10,20,15)
    loc.move(10,10,5)
  }
}

1.4.3 单例对象和伴生对象

在Scala中,没有静态方法或静态字段,所以不能用类名直接访问类中的方法和字段,而是创建类的实例和实例对象对访问类中的方法和字段。但是,Scala中提供了object这个关键字用来实现单例模式,使用关键字object创建的对象为单例对象。

创建单例对象的语法格式如下:

复制代码
object objectName

下面,创建一个单例对象SingletonObject,代码如下示:

scala 复制代码
package cn.itcast.scala

//创建一个单例对象
object SingletonObject{
  def hello(): Unit ={
    println("Hello,This is Singleton object")
  }
}
object Ch09_Singleton {
  def main(args: Array[String]): Unit = {
    //调用hello 方法
    SingletonObject.hello()
  }
}

在一个源文件中有一个类和一个单例对象,若单例对象名与类名相同,则把这个单例对象称作伴生对象(companion object),这个类则被称为是单例对象的伴生类(companion class)。类和伴生对象之间可以相互访问私有的方法和字段。

下面,定义一个伴生对象Dog,演示操作类中的私有方法和字段。具体代码如文件1-10所示。

scala 复制代码
package cn.itcast.scala

//创建c:Dog
class CH10_Dog {
    val id = 666
    private var name = "二哈"

    def printName(): Unit ={
      //在Dog类中可以访问伴生对象Dog的私有字段
      println(CH10_Dog.CONSTANT + name)
    }
}

//伴生对象
object CH10_Dog {
  //伴生对象中添加私有字段
  private var CONSTANT = "汪汪汪。。。"
  def main(args: Array[String]): Unit = {
    val dog = new CH10_Dog
    dog.name  = "二哈 666"
    dog.printName()
  }
}

1.4.4 特质

在Scala中,Trait(特质)的功能类似于Java中的接口,但Trait的功能却比Java中的接口强大。例如,Trait可以对定义字段和方法进行实现,而接口却不能。Scala中的Trait可以被类和对象(Objects)使用关键字extends来继承。

创建特质的语法格式如下:

复制代码
trait traitName

下面,创建一个特质Animal,演示类继承特质并访问特质中方法的操作。具体代码如下所示。

scala 复制代码
package cn.itcast.scala
//定义特质
trait Animal{
  //定义一个抽象方法(没有实现的方法)
  def spek()
  
  def listen(): Unit ={

  }
  
  def run(): Unit ={
    println("I'm runing")
  }
}

//定义类,继承特质
class Ch11_People extends Animal {
  override def spek(): Unit = {
    println("I'm speaking English")
  }
}
object Ch11_People {
  def main(args: Array[String]): Unit = {
    val people = new Ch11_People

    people.spek()
    people.listen()
    people.run()
  }
}

注:特质允许继承多个,用with关键字。如下所示:

复制代码
class Ch11_People extends Animal with A

转载自:https://blog.csdn.net/u014727709/article/details/133915097

欢迎start,欢迎评论,欢迎指正

相关推荐
闪闪发亮的小星星13 小时前
高斯光以及高斯光公式解释
笔记
cqbzcsq14 小时前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
极光代码工作室14 小时前
基于数据仓库的电商数据分析平台
大数据·hadoop·python·spark·数据可视化
JLWcai2025100914 小时前
铸造领域树脂砂轮|金利威多场景解决方案,20 + 配方覆盖全需求
mongodb·zookeeper·eureka·spark·rabbitmq·memcached·storm
阿米亚波15 小时前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.15 小时前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余16 小时前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.16 小时前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央17 小时前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器18 小时前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记