您好,登錄后才能下訂單哦!
這篇“php實現自動加載的示例分析”文章,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要參考一下,對于“php實現自動加載的示例分析”,小編整理了以下知識點,請大家跟著小編的步伐一步一步的慢慢理解,接下來就讓我們進入主題吧。
php是一個嵌套的縮寫名稱,是英文超級文本預處理語言,它的語法混合了C、Java、Perl以及php自創新的語法,主要用來做網站開發,許多小型網站都用php開發,因為php是開源的,從而使得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
使用自動加載器,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。
方法重載是使用具有不同簽名的相同方法名稱的現象。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實現自動加載的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。