我正在研究一些在Ruby中深度复制对象的技术(MRI 1.9.3).
我遇到了以下示例,但我不确定#dup方法实现.我测试了它并且确实有效,但是我不理解该方法的逻辑步骤,因此我在自己的代码中使用它并不舒服.
是语句@name = @name.dup引用伊娃内的副本?怎么样?我看不出来.
请问有人解释一下吗?
还有,有更好的方法吗?
class MyClass
attr_accessor :name
def initialize(arg_str) # called on MyClass.new("string")
@name = arg_str # initialize an instance variable
end
def dup
the_copy = super # shallow copy calling Object.dup
@name = @name.dup # new copy of istance variable
return the_copy # return the copied object
end
end
Run Code Online (Sandbox Code Playgroud)
这是一个非常薄的,非常具体的"深层复制"实现.它的演示是@name在克隆中创建一个独立的实例变量,以便修改具有就地操作的实例的名称不会产生更改克隆的副作用.
通常,深度复制操作对于嵌套数组或散列等内容很重要,但它们也适用于具有引用该类事物的属性的任何对象.
在你的情况下,要使用更健壮的dup方法创建一个对象,你应该调用dup每个有问题的属性,但我认为这个例子有点破碎.它的作用是用@name原件替换原件,这可能会破坏你的任何参考.
更好的版本是:
def dup
copy = super
copy.make_independent!
copy
end
def make_independent!
instance_variables.each do |var|
value = instance_variable_get(var)
if (value.respond_to?(:dup))
instance_variable_set(var, value.dup)
end
end
end
Run Code Online (Sandbox Code Playgroud)
这应该具有复制支持该dup方法的任何实例变量的效果.这会跳过数字,布尔值等nil无法复制的内容.
| 归档时间: |
|
| 查看次数: |
2534 次 |
| 最近记录: |