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):同意本对象及其父对象对其进行操作操纵 。