"Another"類的對象現在擁有了父類(Something)的全部的數據成員及方法,而且還加上了自已的數據成 
員和方法。 
你可以使用 
$obj2=new Something; 
$obj2->setX(6); 
$obj2->setY(7); 
PHP現在還不支持多重繼承,所以你不能從兩個或兩個以上類派生出新的類來。
你可以在派生類中重定義一個方法,如果我們在"Another"類中重定義了getX方法,我們就不能使 
用"Something"中的getX方法了。如果你在派生類中聲明了一個與基派同名的數據成員,那么當你處理它時, 
它將“隱藏”基類的數據成員。 
你可以在你的類中定義構造函數。構造函數是一個與類名同名的方法,當你創建一個類的對象時會被調 
用,例如: 
-------------------------------------------------------------------------------- 
<?php 
class Something { 
var $x; 
function Something($y) { 
$this->x=$y; 
} 
function setX($v) { 
$this->x=$v; 
} 
function getX() { 
return $this->x; 
} 
} 
?>-------------------------------------------------------------------------------- 
所以你可以創建一個對象,通過: 
$obj=new Something(6);
構造函數會自動地把6賦值給數據變量x。構造函數和方法都是普通的PHP函數,所以你可以使用缺省參數。
function Something($x="3",$y="5")
接著:
$obj=new Something(); // x=3 and y=5 
$obj=new Something(8); // x=8 and y=5 
$obj=new Something(8,9); // x=8 and y=9 
缺省參數使用C++的方式,所以你不能忽略Y的值,而給X一個缺省參數,參數是從左到右賦值的,如果 
傳入的參數少于要求的參數時,其作的將使用缺省參數。 
當一個派生類的對象被創建時,只有它的構造函數被調用,父類的構造函數沒被調用,如果你想調用基 
類的構造函數,你必須要在派生類的構造函數中顯示調用。可以這樣做是因為在派生類中所有父類的方法都 
是可用的。 
-------------------------------------------------------------------------------- 
<?php 
function Another() { 
$this->y=5; 
$this->Something(); 
//顯示調用基類構造函數 
} 
?>-------------------------------------------------------------------------------- 
OOP的一個很好的機制是使用抽象類。抽象類是不能實例化,只能提供給派生類一個接口。設計者通常 
使用抽象類來強迫程序員從基類派生,這樣可以確保新的類包含一些期待的功能。在PHP中沒有標準的方法, 
但是: 
如果你需要這個特性,可以通過定義基類,并在它的構造函數后加上"die" 的調用,這樣就可以保證基 
類是不可實例化的,現在在每一個方法(接口)后面加上"die" 語句,所以,如果一個程序員在派生類中沒有 
覆蓋方法,將引發一個錯誤。而且因為PHP 是無類型的,你可能需要確認一個對象是來自于你的基類的派生 
類,那么在基類中增加一個方法來實義類的身份(返回某種標識id),并且在你接收到一個對象參數時校驗 
這個值。當然,如果一個邪惡不好的程序員在派生類中覆蓋了這個方法,這種方法就不起作用了,不過一般 
問題多發現在懶惰的程序員身上,而不是邪惡的程序員。 
當然,能夠讓基類對程序員無法看到是很好的,只要將接口打印出來做他們的工作就可以了。
在PHP中沒有析構函數。
