PHP4中已經有了重載的語法來建立對於外部物件模型的映射,就像Java和COM那樣. PHP5帶來了強大的物件導向重載,允許程式設計師建立自訂的行為來存取屬性和呼叫方法.
重載可以透過__get, __set, and __call幾個特殊方法來進行. 當Zend引擎試圖存取一個成員並沒有找到時,PHP將會呼叫這些方法.在
例圖1中,__get和__set代替所有對屬性變數數組的存取. 如果必要,你可以實現任何類型你想要的過濾. 例如,腳本可以禁止設定屬性值, 在開始時用一定的前綴或包含一定類型的值.
__call方法說明了你如何呼叫未經定義的方法. 你呼叫未定義方法時,方法名稱和方法接收的參數將會傳給__call方法, PHP傳遞__call的值回傳給未定義的方法.
User-level overloading
<?php
class Overloader
{
private $properties = array();
function __get($property_name)
{
if(isset($this->properties[$property_name]))
{
return($this->properties[$property_name]);
}
else
{
return(NULL);
}
}
function __set($property_name, $value)
{
$this->properties[$property_name] = $value;
}
function __call($function_name, $args)
{
print("Invoking $function_name()n");
print("Arguments: ");
print_r($args);
return(TRUE);
}
}
$o = new Overloader();
//invoke __set() 給一個不存在的屬性變數賦值,啟動__set()
$o->dynaProp = "Dynamic Content";
//invoke __get() 啟動__get()
print($o->dynaProp . "n");
//invoke __call() 啟動__call()
$o->dynaMethod("Leon", "Zeev");
?>
類別的自動載入
當你嘗試使用一個未定義的類別時,PHP會報告一個致命錯誤.解決方法就是添加一個類別,可以用include包含一個檔案. 畢竟你知道要用到哪個類別. 但是,PHP提供了類別的自動載入功能, 這可以節省程式設計的時間. 當你嘗試使用一個PHP沒有組織到的類別, 它會尋找一個__autoload的全域函數. 如果存在這個函數,PHP會用一個參數來呼叫它,參數即類別的名稱.
範例圖2說明了__autoload是如何使用的. 它假設當前目錄下每個檔案對應一個類別. 當腳本嘗試來產生一個類別User的實例,PHP會執行__autoload. 腳本假設class_User.php中定義有User類別.. 不管呼叫時是大寫還是小寫,PHP將回傳名稱的小寫.
Class autoloading
<?php
//define autoload function
function __autoload($class)
{
include("class_" . ucfirst($class) . ".php");
}
//use a class that must be autoloaded
$u = new User;
$u->name = "Leon";
$u->printName();
?>