我可能会以错误的方式接近这个,但我希望有一个像这样的对象:
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方法并指定类型,但它应该是一个单行.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。