本文实例讲述了php面向对象程序设计之对象克隆clone和魔术方法__clone()用法。分享给大家供大家参考,具体如下:
1.对象克隆 clone
php4面向对象功能一个很大的缺点,是将对象视为另一种数据类型,这使得很多常见的oop方法无法使用,如设计模式。这些方法依赖于将对象作为引用传递给其他类方法,而不是作为值传递,而按值传递却是php的默认做法。幸好,php5解决了这个问题,现在所有对象在默认情况下都被视为引用。但是,由于所有对象都被视为引用而不是值,所以现在复制对象更为困难。如果尝试复制一个引用的对象,这只会指向原对象的地址位置。为了解决复制问题,php提供了一种克隆clone
(关键字,不是方法)对象的显式方法。
可以在对象前面加clone
关键字来克隆对象,如下:
destinationobject = clone targetobject;
克隆对象:
<?phpclass person{ var $name; var $x; var $age; function __construct($name, $x, $age){ $this->name = $name; $this->x = $x; $this->age = $age; } function say(){ echo "我的名字:" . $this->name . ",性别:" . $this->x . ",年龄:" .$this->age . "<br />"; }}$person1 国庆节的活动= new person("张三三", "男", 23);$person2 = clone $person1; //使用clone关键字克隆/复制对象,创建一个对象的副本$person3 = $person1; //这不是复制对象,而是为对象多复制出一个访问该对象的引用$person1->say(); //调用原对象中的说话方式,打印原对象中的全部属性值$person2->say(); //调用副本对象中的说话方式,打印克隆对象中的全部属性值$person3->say(); //调用原对象中的说话方式,打印原对象中的全部属性值?>
2.魔术方法__clone()
在上面的程序中一共创建了两个对象,其中有一个对象是通过clone
关键字克隆出来的副本。两个对象完全能独立,但他们中的成员及属性的值完全一样。如果需要对克隆后的副本对象在克隆时重新为成员属性赋初值,则可以在类中声明一个魔术方法“__clone()”。该方法是在对象克隆时自动调用的,所以就可以通过全国二本院校此方法对克隆后的副本重新初始化。__clone()
方法不需要任何参数。将上例中的代码改写一下,在类中添加魔术方法__clone()
,为副本对象中的成员属性重新初始化。
<?phpclass person{ var $name; var $x; var $age; function __construct($name, $x, $age){ $this->name = $name; $this->xsin值 = $x; $this->age = $age; } function say(){ echo "我的名字:" . $this->name . ",性别:" . $this->x . ",年龄:" .$this->age . "<br />"; } function __clone(){ $this->name = "李四四"; //为副本对象中的name属性重新赋值 $this->age = 10; //为副本对象中的age属性重新赋值 }}$person1 = new person("张三三", "男", 23);$person2 = clone $person1; //创建一个对象的副本,并自动调用类中的__clone()方法$person1->say(); //调用原对象中的说话方式,打印原对象中的全部属性值$person2->say(); //调用副本对象中的说话方式,打印克隆对象中的全部属性值?>
运行结果:
我的名字:张三三,性别:男,年龄:23
我的名字:李四四,性别:男,年龄:10
3.单例类的加强:禁止克隆
对于一个类的对象,如果使用“clone运算符”,就会复制出一个和当前对象完全一样的新对象出来,并且,此时还会自动调用该类的魔术方法:__clone()
(只要该类中有该方法)。
则要实现单例类,就应该对这个单例类的对象“禁止克隆”。在php中,为防止对单例类对象的克隆来打破单例类的上述实现形式,通常还为其提供一个空的私有 (private
修饰的)__clone小相框()
方法。
首先来看“未做禁止克隆”的效果:
<?phpclass singetonbasic { private static $instance; //静态变量要私有化,防止类外修改 private function __construct() { //构造函数私有化,类外不能直接新建对象}//private function __clone() {} //在__clone()前用private修饰,用来禁止克隆public static function getinstance() { //公共的静态方法,public——外部的接口,s芝麻拍客tatic——不使用对象而是通过类名访问 if (!(lf::$instance instanceof lf)) { //私有静态变量$instance为空 lf::$instance = new lf(); //新建为自身的对象,并赋值给私有变量$instance } return lf::$instance; //返回私有变量$instance}}$a = singetonbasic::getinstance();$b = singetonbasic::getinstance();var_dump($a === $b); //结果为:boolean true a和b指向的是同一个对象$c = clone $a;var_dump($a === $c); //结果为:boolean fal a和c指向的不是同一个对象?>
运行结果为
boolean true
boolean fal
我们“作禁止克隆”处理,即把上面代码中的
private function __clone() {} //在__clone()前用private修饰,用来禁止克隆
这行代码去掉注释。
运行结果为
boolean true
fatal error: call to private singetonbasic::__clone()
也就是,在克隆的时候,自动调用了__clone()
,但是该方法被private
修饰,不能再类的外部直接调用,结果报错。
更多关于php相关内容感兴趣的读者可查看本站专题:《php面向对象程序设计入门教程》、《php数组(array)操作技巧大全》、《php基本语法入门教程》、《php运算与运算符用法总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家php程序设计有所帮助。
本文发布于:2023-04-07 07:55:41,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/a8a001ccfc4c6d72e487d0e238c1c575.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:PHP面向对象程序设计之对象克隆clone和魔术方法.doc
本文 PDF 下载地址:PHP面向对象程序设计之对象克隆clone和魔术方法.pdf
留言与评论(共有 0 条评论) |