php4和php5区别 |
PHP5 中的对象已经进行了较系统、较全面的调整,现在的样子可能看起来会有些 类似于 Java 。本小节着重讲述 PHP5 中新的对象模式,并举了一些较简易的例子来 注明 。就让本节成为你的 PHP5 之旅的一个新起点吧 。:) * 构造函数和析构函数 * 对象的 引用 * 对象的克隆 * 对象中的私有、公共及受 掩护模式 * 接口 (Interfaces) * 形象类 * __call * __set 和 __get * 静态成员 构造函数和析构函数 在 PHP4 中,当函数与对象同名时,这个函数将成为该对象的 构造函数,而且在 PHP4 中没有析构函数的概念 。 在 PHP5 中, 构造函数被统一命名为 __construct,而且引入了析构函数的概念,被统一命名为 __destruct 。 例一: 构造函数和析构函数 class foo { var $x; function __construct($x) { $this->x = $x; } function display() { print($this->x); } function __destruct() { print("bye bye"); } } $o1 = new foo(4); $o1->display(); ?> 在上面的例子中,当你终止调用 foo 类的时候,其析构函数将会被调用,上例中会输出 “bye bye” 。 对象的 引用 家喻户晓,在PHP4 中,传递变量给一个函数或 步骤,实际是把这个变量做了一次复制,也就 象征着你传给函数或 步骤的是这个变量的一个副本,除非你 使用了 引用符号 “&” 来申明是要做一个 引用,而不是一个 Copy 。在 PHP5 中,对象总是以 引用的 模式存在的,对象中的赋值操作同样也都是一个 引用操作 。 例二:对象的 引用 class foo { var $x; function setX($x) { $this->x = $x; } function getX() { return $this->x; } } $o1 = new foo; $o1->setX(4); $o2 = $o1; $o1->setX(5); if($o1->getX() == $o2->getX()) print("Oh my god!"); ?> 对象的克隆 如上所述,当一个对象始终以 引用的 模式来被调用时,假如我想得到该对象的一个副本,该怎么办呢?PHP5 提供了一个新的 性能,便是对象的克隆,语法为 __clone 。 例三:对象的克隆 class foo { var $x; function setX($x) { $this->x = $x; } function getX() { return $this->x; } } $o1 = new foo; $o1->setX(4); $o2 = $o1->__clone(); $o1->setX(5); if($o1->getX() != $o2->getX()) print("Copies are independant"); ?> 对象克隆的 步骤在其它众多 利用程序语言中都是存在的,所以你 毋庸 担心它的 巩固性 。:) 对象中的私有、公共及 掩护模式 PHP4 中,一个对象的全部 步骤和变量都是公共的,这 象征着你 可以在一个对象的外部操作其中的任意一个变量和 步骤 。PHP5 引入了三种新的用来操纵这种存取权限的模式,它们是:公共的(Public)、受 掩护的(Protected)及私有的(Private) 。 公共模式(Public):同意在对象外部进行操作操纵 。 私有模式(Private):只同意本对象内的 步骤对其进行操作操纵 。 受 掩护模式(Protected):同意本对象及其父对象对其进行操作操纵 。 |