php4和php5區別

PHP5 中的對象已經進行了較系統、較全面的調整,如今的樣子可能看起來會有些相似於 Java。本小節着重講述 PHP5 中新的對象模式,並舉了一些較簡易的例子來講明。就讓本節成爲你的 PHP5 之旅的一個新起函數

  PHP5 中的對象已經進行了較系統、較全面的調整,如今的樣子可能看起來會有些相似於 Java。本小節着重講述 PHP5 中新的對象模式,並舉了一些較簡易的例子來講明。就讓本節成爲你的 PHP5 之旅的一個新起點吧。:)this

* 構造函數和析構函數對象

* 對象的引用接口

* 對象的克隆get

* 對象中的私有、公共及受保護模式io

* 接口 (Interfaces)function

* 抽象類class

* __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):容許本對象及其父對象對其進行操做控制。

相關文章
相關標籤/搜索