下面是呼叫一個模型(Module)的函數。這個函數的基本功能是指定一個模型(抽象化為類別)的名稱,然後它會在模型目錄下面尋找這個類別的腳本實例化以後返回。這樣的做法有一點好處就是載入和實例化是自動的,你可以得到最大的靈活性。下面請看下面的程式碼,它並不長而且不複雜:
function &load_class($class_name, $param = null, $instantiate = true)
{ 🎜> $class_name = ucfirst(strtolower($class_name));
if (isset($objects[$class_name) }
$class_file = DIR_MODELS . "/{$class_name}.inc.php";
if (file_exists($class_file)) {
_exists($class_name)) {
return false;
} else {
$obj將 return $objects[$class_name];
}
} else {
if ($instantiate) {
$ return null;
}
}函數只有三個參數,分別是 $class_name 、$ param 以及 $instaniate ,其中 $param 是建構函數的參數,$instaniate 是可選的。請注意函數中的 $objects 數組是靜態變量,也就是調用完這個函數的時候數組並不會釋放,下次呼叫此函數時這個數組的資料是會保存的。這樣做的好處就是可以將大部分的類別實例了以後,如需要重複調用則直接返回這個類別的實例就可以了,避免了重複調用,提高了性能。代碼如下:
static $objects = array();
if (isset($objects[$class_name]) }其它繼續的程式碼就是檢測是否有這個類名稱的文件,如果有載入這個文件並尋找指定名稱的類,如找到了這個類以後就實例化。這要求腳本中類別的名稱必須和腳本的檔案名稱是一致的。我想這也有利於以後的程式碼管理。
$instaniate 參數這個時候就發揮了功效,這個參數會告訴函數如果未找到則在 $objects 下面做一個標記位(null)避免函數又重複的尋找文件名並重複載入和尋找。
$class_file = DIR_MODELS . "/{$class_name}.inc.php";
if (file_exists($class_file)){Yo
return false;
} $class_name($param);
return $objects[$class_name];
> } else {
if ($instantiate) {
}
return null;
}其中語句:
$objects[$class_name ] =& new $class_name($param);可以多次的推敲。 $class_name 在函數中是一個字串變數。關鍵字 new 可以動態的實例化指定字串的類別(如果存在的話)。有關此呼叫方法可以請參閱 PHP 手冊和這裡。
此函數的缺點就是如何去考慮傳遞不同個數的參數給每個不同的類別的建構子。或許可以使用 call_user_func_array 等函數來實現,但是這樣的做法非常的不 Grace。在這裡需要推敲一下。其實 file_exists 等檔案存在的測試可以交給 __autoload 函數處理,不過由於其他的函數例如 interface_exists 等也會呼叫 __autolaod 函數,出於相容性的考慮,所以只在函數內做一個簡單的測試。
PHP5 相對 PHP4 而言更的物件導向。我想是時候更新我們我們的編碼想法了。有關 PHP5 的類別和對象,這裡有一個非常好的教學。
以上就介紹了實例 PHP 實例化類別的一點摘記,包含了實例方面的內容,希望對PHP教程有興趣的朋友有所幫助。