Scala:如何在超类上实现克隆方法,并在子类中使用它?

我可能会以错误的方式接近这个,但我希望有一个像这样的对象:

class MyDataStructure {
  def myClone = {
    val clone = new MyDataStructure
    // do stuff to make clone the same as this
    ...
    clone
  }
}

class MyDataStructureExtended(val foo: String) extends MyDataStructure

然后:

val data = MyDataStructureExtended
val dataClone = data.clone
println(dataClone.foo)

所以,问题是dataClone的类型是MyDataStructure,而不是我希望的MyDataStructureExtended.

我想过将类型T添加到超类中,子类可以指定(例如自己),但这似乎不太有希望.

解决方法

假设你想最小化子类中的仪式数量,这是我的建议:

class A extends Cloneable {
  protected[this] def myCloneImpl[T] = {
    val justLikeMe = this.clone
    // copy values and such.
    // Note that the Object.clone method already made a shallow copy,but you may want
    // to deepen the copy or do other operations.
    justLikeMe.asInstanceOf[T]
  }
  def myClone = myCloneImpl[A]
}

class B extends A {
  override def myClone = myCloneImpl[B]
}

通过扩展java.lang.Cloneable并调用Object.clone方法,可以确保运行时类型与要克隆的对象相同.静态类型是使用类型转换(asInstanceOf [T])强制的.您需要覆盖每个子类中的myClone方法并指定类型,但它应该是一个单行.

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...