php自動加載代碼實例詳解
1. 讓我們為 PHP 創建枚舉,提供一些代碼示例
如果我們的代碼需要對枚舉常量和值進行更多驗證,該怎麼辦?
根據使用情況,我通常會使用類似以下的簡單內容:
abstract class DaysOfWeek { const Sunday = 0; const Monday = 1; // etc. } $today = DaysOfWeek::Sunday;
這是一個擴展的示例,可以更好地服務於更廣泛的案例:
abstract class BasicEnum { private static $constCacheArray = NULL; private static function getConstants() { if (self::$constCacheArray == NULL) { self::$constCacheArray = []; } $calledClass = get_called_class(); if (!array_key_exists($calledClass, self::$constCacheArray)) { $reflect = new ReflectionClass($calledClass); self::$constCacheArray[$calledClass] = $reflect - > getConstants(); } return self::$constCacheArray[$calledClass]; } public static function isValidName($name, $strict = false) { $constants = self::getConstants(); if ($strict) { return array_key_exists($name, $constants); } $keys = array_map('strtolower', array_keys($constants)); return in_array(strtolower($name), $keys); } public static function isValidValue($value, $strict = true) { $values = array_values(self::getConstants()); return in_array($value, $values, $strict); } }
我們可以將其用作:
abstract class DaysOfWeek extends BasicEnum { const Sunday = 0; const Monday = 1; const Tuesday = 2; const Wednesday = 3; const Thursday = 4; const Friday = 5; const Saturday = 6; } DaysOfWeek::isValidName('Humpday'); // false DaysOfWeek::isValidName('Monday'); // true DaysOfWeek::isValidName('monday'); // true DaysOfWeek::isValidName('monday', $strict = true); // false DaysOfWeek::isValidName(0); // false DaysOfWeek::isValidValue(0); // true DaysOfWeek::isValidValue(5); // true DaysOfWeek::isValidValue(7); // false DaysOfWeek::isValidValue('Friday'); // false
2. 什麼是 PHP 自動加載類?
使用自動加載器,PHP 允許在由於錯誤而失敗之前最後一次加載類或接口。
PHP 中的 spl_autoload_register() 函數可以註冊任意數量的自動加載器,即使未定義類和接口也可以自動加載。
spl_autoload_register(function ($classname) { include $classname . '.php'; }); $object = new Class1(); $object2 = new Class2();
在上面的示例中,我們不需要包含 Class1.php 和 Class2.php。spl_autoload_register() 函數將自動加載 Class1.php 和 Class2.php。
3. PHP 是否支持方法重載?
方法重載是使用具有不同簽名的相同方法名稱的現象。PHP 中函數簽名僅基於它們的名稱,並且不包含參數列表,因此不能有兩個具有相同名稱的函數,所以 PHP 不支持方法重載。
但是,您可以聲明一個可變函數,它接受可變數量的參數。您可以使用 func_num_args() 和 func_get_arg() 來傳遞參數並正常使用它們。
function myFunc() { for ($i = 0; $i < func_num_args(); $i++) { printf("Argument %d: %s\n", $i, func_get_arg($i)); } } /* Argument 0: a Argument 1: 2 Argument 2: 3.5 */ myFunc('a', 2, 3.5);
問答:不是有 __ autoload 嗎 為什麼不用?
自動加載的原理以及__autoload 的使用:
自動加載的原理,就是在我們 new 一個 class 的時候,PHP 系統如果找不到你這個類,就會去自動調用本文件中的__autoload ($class_name) 方法,我們 new 的這個 class_name 就成為這個方法的參數。所以我們就可以在這個方法中根據我們需要 new class_name 的各種判斷和劃分就去 require 對應的路徑類文件,從而實現自動加載。
spl_autoload_register 的使用:
如果一個項目過大,或者需要不同的自動加載來加載不同路徑的文件,這個時候 autoload 就不好用瞭,
原因是一個項目中隻能有一個這樣的 autoload () 函數,因為 PHP 不允許函數重名,
也就是說你不能聲明 2 個__autoload () 函數文件,否則會報致命錯誤,
所以,可以用新的 spl_autoload_register () 來取代它。並且,它執行效率更高,更靈活。
到此這篇關於php自動加載代碼實例詳解的文章就介紹到這瞭,更多相關php自動加載內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!