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