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(); ?>