導語:PHP4和PHP5,已經是兩個版本了。下面的是本站小編為大家蒐集的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)。