当前位置:Gxlcms > PHP教程 > php面向对象Clone与序列化

php面向对象Clone与序列化

时间:2021-07-01 10:21:17 帮助过:21人阅读

对象的复制时有三种方案:

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教程有兴趣的朋友有所帮助。

人气教程排行