scala的类介绍

scala的类、抽象类、接口、对象

  1. class :类, 通过new关键字来实例化,每次实例化都会创建一个新的对象;用来定义普通的类。
  2. object:对象,用来定义一个单例对象的,它只有一个实例,且在程序运行期间只会被创建一次。object中定义的方法和变量都是静态的,可以通过对象名直接调用;在实际编程中,object通常用来定义工具类、单例模式等场景
  3. trait : 特质(Trait),是一种类似于Java中接口的概念,用来定义一组可复用的方法和字段。可以包含实现代码,特质可以被类和对象混入,从而实现代码的复用和组合。
  4. extends : 用于类的继承,它可以让一个类继承另一个类的所有成员,包括成员变量、成员方法和构造函数
  5. with : 特质trait混入使用with关键字,一个类或对象可以混入多个特质,混入的特质可以覆盖类或对象中的同名方法和字段,这样就可以实现代码的复用和组合
    例如,下面的代码定义了一个Logger特质,它有一个log方法,然后定义了一个Person类,它混入了Logger特质:
trait Logger {
  def log(msg: String): Unit = println(s"[${java.time.Instant.now}] $msg")
}

class Person(val name: String) with Logger {
  def greet(): Unit = {
    log(s"Greeting from $name")
    println(s"Hello, my name is $name")
  }
}
#在上面的代码中,Person类使用with关键字混入了Logger特质,并在greet方法中调用了log方法。这样,Person类就可以使用Logger特质的成员了。

你可能感兴趣的:(hive/sparksql,scala,开发语言)