对象的复制时有三种方案:
1,直接复制 $a = $b
这种是浅拷贝,当改变$a的时候$b也会改变,因为他们指向的是同一块堆区
2,clone复制 $a = clone $b
这种拷贝貌似是深拷贝,当$a发生变化的时候$b不会跟着变化,同时PHP提供了魔术方法__Clone()可以自定义Clone复制,哪些属性不想被复制,复制过程中需要哪些改变,都可以在__clone()方法中自定义。
但是这种复制的方法有个缺陷,需要注意,如果类中的某个属性的类型是另外一个类,那么在Clone的时候这个属性会不会被深拷贝,是不是很尴尬,当然这点缺陷是可以通过魔术方法__clone来进行弥补的,在__clone()方法中为这个属性new一个新的类就是了。
class test{ private $name; private $sex; private $demo; public function __construct($name,$sex,$demo){ $this->name = $name; $this->sex = $sex; $this->demo = $demo; } public function __set($key,$value){ $this->{$key} = $value; } public function __get($key){ return $this->{$key}; } public function __clone(){ $this->name='null'; //这里可以自定义clone } }
class demo{ private $name; public function __construct($name='demo01'){ $this->name = $name; } public function __set($key,$value){ $this->{$key} = $value; } public function __get($key){ return $this->{$key}; } }
$t = new test('aa', 'bb',new demo('d01')); $d = clone $t; //$d->name='nihao'; $d->demo->name = 'd02'; var_dump($t); //结果 $t->demo->name d02使用clone弥补
public function __clone(){ $this->name='null'; $this->demo = new demo('init'); }
3,序列化复制
$b = unserialize(serialize($t));这样不需要使用clone魔术方法既可以实现属性中引用类型的深拷贝了。
以上就介绍了php面向对象Clone与序列化,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。