scala trait,class 和 object在内存中的状态

本文探讨了 Scala 中的 Trait、抽象类(Abstract Class)和 Object 的特性。Trait 的变量不能直接访问,且每个继承 Trait 的实例都会生成一个 Trait 对象。与 Java 不同,Trait 的属性实际上是方法调用。抽象类和 Trait 在内存中的表现类似,但抽象类是单继承。Object 是全局唯一的单例,其方法和属性为静态,且不支持泛型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

trait

  • trait的变量并不能直接访问,说明不是静态的.
  • trait既能被class继承也能被object继承
  • 每一个继承trait的类生成实例的时候(无论是class还是object)都换先生成一个trait实例(或者说对象)
  • java的属性是static final的,全局唯一。而trait的属性实际上是方法调用而已。
class Son()
trait Father {
  println("i am trait")
  val son = new Son()
  var b = new Son()
}

class Child1 extends Father
class Child2 extends Father
object Child3 extends Father
object Child4 extends Father

对于上面的代码,如果Child1和Child2的实例的son(不能是case class,因为case 自己实现了hashCode)属性相等.那说明他们指向同一个Father实例,反之则不是。下面的代码输出都是false,说明无论object还是class在生成对象的时候,father trait都是单独生成了一个实例。

object Context {
  def main(args: Array[String]): Unit = {
    //    println(Father.a) // error trait的变量并不能直接访问,说明不是静态的。
    val child1 = new Child1
    val child2 = new Child2

    println(child1.son == child2.son) // false
    println(Child3.son == Child4.son)// false
  }
}

抽象类

在scala中接口和抽象类在内存中没什么区别。

  • 抽象类的变量并不能直接访问,说明不是静态的.
  • 抽象类既能被class继承也能被object继承
  • 每一个继承抽象类的类生成实例的时候(无论是class还是object)都换先生成一个抽象类实例(或者说对象)
  • 唯一的区别:trait多继承,抽象类是单继承

object

  • object是全局唯一的,换句话说是单例的
  • object的方法和属性都是静态的
  • object不可被继承,反编译的结果是final类
  • object不支持泛型
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值