Scala之高阶面向对象编程

发布于:2024-09-05 ⋅ 阅读:(14) ⋅ 点赞:(0)

Scala之高阶面向对象编程


文章目录

  • Scala之高阶面向对象编程
    • 写在前面
      • 继承
    • 封装
      • 抽象
    • 单例对象
    • 特质
      • 基本语法
      • 动态混入(方便扩展程序功能)
      • 初始化叠加
      • 功能叠加
    • 扩展


写在前面

  • 操作系统:Windows10
  • JDK版本:jdk1.8
  • Maven版本:Maven-3.5.4
  • Scala版本:Scala-2.12.11
  • IDE工具:IntelliJ IDEA 2019.2.3

继承

和Java一样,Scala中的继承也是单继承,且使用 extends 关键字。

class Person {

}

class User extends Person {

}

构造对象时需要考虑构造方法的执行顺序

封装

封装就是把抽象出的数据和对数据的操作封装在一起,数据被保护在内部,程序的其它部分只有通过被授权的操作(成员方法),才能对数据进行访问。

  • 将属性进行私有化

  • 提供一个公共的set方法,用于对属性赋值

  • 提供一个公共的get方法,用于获取属性的值

抽象

  • Scala将一个不完整的类称之为抽象类。
abstract class Person {

}
  • Scala中如果一个方法只有声明而没有实现,那么是抽象方法,因为它不完整。
abstract class Person {
  def test():Unit
}
  • Scala中如果一个属性只有声明没有初始化,那么是抽象属性,因为它不完整。
abstract class Person {
  var name:String
}
  • 子类如果继承抽象类,必须实现抽象方法或补全抽象属性,否则也必须声明为抽象的,因为依然不完整。
abstract class Person {
  var name:String
}
class User extends Person {
  var name : String = "whybigdata"
}

单例对象

  • 所谓的单例对象,就是在程序运行过程中,指定类的对象只能创建一个,而不能创建多个。这样的对象可以由特殊的设计方式获得,也可以由语言本身设计得到,比如object伴生对象

  • Scala语言是完全面向对象的语言,所以并没有静态的操作(即在Scala中没有静态的概念)。但是为了能够和Java语言交互(因为Java中有静态概念),就产生了一种特殊的对象来模拟类对象,该对象为单例对象。若单例对象名与类名一致,则称该单例对象这个类的伴生对象,这个类的所有“静态”内容都可以放置在它的伴生对象中声明,然后通过伴生对象名称直接调用

  • 如果类名和伴生对象名称保持一致,那么这个类称之为伴生类。Scala编译器可以通过伴生对象的apply方法创建伴生类对象。apply方法可以重载,并传递参数,且可由Scala编译器自动识别。所以在使用时,其实是可以省略的。

class User { // 伴生类

}

object User { // 伴生对象
  def apply() = new User() // 构造伴生类对象
}

......

val user1 = new User()// 通过构造方法创建对象
Val user2 = User.apply() // 通过伴生对象的apply方法构造伴生类对象 
val user3 = User() // scala编译器省略apply方法,自动完成调用

特质

Scala将多个类的相同特征从类中剥离出来,形成一个独立的语法结构,称之为“特质”(特征)。这种方式在Java中称之为接口,但是Scala中没有接口的概念。所以scala中没有interface关键字,而是采用特殊的关键字trait来声明特质, 如果一个类符合某一个特征(特质),那么就可以将这个特征(特质)“混入”到类中。这种混入的操作可以在声明类时使用,也可以在创建类对象时动态使用。

基本语法

trait 特质名称

class 类名 extends 父类(特质1) with 特质2 with特质3

trait Operator {

}

trait DB{

}

class MySQL extends Operator with DB{

}

动态混入(方便扩展程序功能)

object ScalaTrait{
  def main(args: Array[String]): Unit = {
    val mysql = new MySQL with Operator
    mysql.insert()
  }
}

trait Operator {
  def insert(): Unit = {
    println("insert data...")
  }
}

class MySQL {

}

初始化叠加

object ScalaTrait{
  def main(args: Array[String]): Unit = {
    val mysql = new MySQL
  }
}

trait Operator {
  println("operator...")
}

trait DB {
  println("database...")
}

class MySQL extends DB with Operator{
  println("mysql...")
}

功能叠加

object ScalaTrait {
  def main(args: Array[String]): Unit = {
    val mysql: MySQL = new MySQL
    mysql.operData()
  }
}

trait Operate{
  def operData():Unit={
   println("操作数据。。")
  }
}

trait DB extends Operate{
  override def operData(): Unit = {
    print("向数据库中。。")
    super.operData()
  }
}

trait Log extends Operate{
  override def operData(): Unit = {
   super.operData()
  }
}

class MySQL extends DB with Log {

}

扩展

  • 类型检查和转换
class Person{

}

object Person {
  def main(args: Array[String]): Unit = {
    val person = new Person
    //(1)判断对象是否为某个类型的实例
    val bool: Boolean = person.isInstanceOf[Person]
    if ( bool ) {
      //(2)将对象转换为某个类型的实例
      val p1: Person = person.asInstanceOf[Person]
      println(p1)
    }
    //(3)获取类的信息
    val pClass: Class[Person] = classOf[Person]
    println(pClass)
  }
}
  • 枚举类和应用类
object Test {
  def main(args: Array[String]): Unit = {
    println(Color.RED)
  }
}

// 枚举类
object Color extends Enumeration {
  val RED = Value(1, "red")
  val YELLOW = Value(2, "yellow")
  val BLUE = Value(3, "blue")
}

// 应用类
object AppTest extends App {
  println("application");
}
  • Type定义新类型

使用type关键字可以定义新的数据数据类型名称,本质上就是类型的一个别名

object Test {
  def main(args: Array[String]): Unit = {
    type S = String
    var v : S = "xyz"
  }
} 

全文结束!


网站公告

今日签到

点亮在社区的每一天
去签到