在给定的场景中,我有一个类:
class shopCart {}
我在那里使用析构函数和构造函数来执行某些操作。
稍后,我想存储购物车的序列化版本。但是,我序列化的对象应该而不是包含析构函数和构造函数方法。
为了实现这一点,我创建了一个类:
class storageCart extends shopCart {
function __construct(){}
function __destruct(){}
}
现在,在存储购物车之前,我必须创建一个类型为storageCart
的新对象,并确保它包含shopCart
的所有属性。
为了满足这一需求,shopCart
有一种方法getInstanceForStorage()
:
public function getInstanceForStorage() {
$storageCart = new storageCart();
foreach(get_object_vars($this) as $k => $v){
$storageCart->{$k}=$v;
}
return $storageCart;
}
问题是,我对新实例(storageCart
(所做的更改似乎会影响原始实例(shopCart
(。
这里需要注意的是,shopCart
的变量之一是一个包含对象(购物车项目(的数组。
我想我遇到了一些对象/实例化/复制/克隆(或缺乏这些(的混乱。但我不知道问题出在哪里,因为在上面的foreach
循环中,我的赋值中没有使用指针。
有人能告诉我们这里发生了什么吗?
注意:这是PHP>5.3
编辑
我尝试复制包含对象的数组的内容,方法是将它们分配给新对象中的同一个数组,并使用clone
,但令我惊讶的是,我最终还是得到了一个引用。我不明白。
克隆对象中的对象是否仍然是原始对象的引用?
您想要的技术被称为"深度克隆",可以在对象中使用__clone((魔术方法轻松实现:
/**
* Implement PHP __clone to create a deep clone, not just a shallow copy.
*/
public function __clone()
{
foreach ($this as $key => $val) {
if (is_object($val) || (is_array($val))) {
$this->{$key} = clone $val;
}
}
}
只需在你的主类中定义它,在你作为属性存储在该类中的所有对象的类中,一直到
当然,如果您持有一个对象数组作为属性,则需要调整此代码以遍历该数组。