欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

php面向对象Clone与序列化

程序员文章站 2022-05-24 22:13:16
...
对象的复制时有三种方案:

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