您好,登錄后才能下訂單哦!
這篇“php實現(xiàn)自動加載的示例分析”文章,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要參考一下,對于“php實現(xiàn)自動加載的示例分析”,小編整理了以下知識點,請大家跟著小編的步伐一步一步的慢慢理解,接下來就讓我們進入主題吧。
php是一個嵌套的縮寫名稱,是英文超級文本預(yù)處理語言,它的語法混合了C、Java、Perl以及php自創(chuàng)新的語法,主要用來做網(wǎng)站開發(fā),許多小型網(wǎng)站都用php開發(fā),因為php是開源的,從而使得php經(jīng)久不衰。
如果我們的代碼需要對枚舉常量和值進行更多驗證,該怎么辦?
根據(jù)使用情況,我通常會使用類似以下的簡單內(nèi)容:
abstract class DaysOfWeek { const Sunday = 0; const Monday = 1; // etc. } $today = DaysOfWeek::Sunday;
這是一個擴展的示例,可以更好地服務(wù)于更廣泛的案例:
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() 函數(shù)可以注冊任意數(shù)量的自動加載器,即使未定義類和接口也可以自動加載。
spl_autoload_register(function ($classname) { include $classname . '.php'; }); $object = new Class1(); $object2 = new Class2();
在上面的示例中,我們不需要包含 Class1.php 和 Class2.php。spl_autoload_register() 函數(shù)將自動加載 Class1.php 和 Class2.php。
方法重載是使用具有不同簽名的相同方法名稱的現(xiàn)象。PHP 中函數(shù)簽名僅基于它們的名稱,并且不包含參數(shù)列表,因此不能有兩個具有相同名稱的函數(shù),所以 PHP 不支持方法重載。
但是,您可以聲明一個可變函數(shù),它接受可變數(shù)量的參數(shù)。您可以使用 func_num_args() 和 func_get_arg() 來傳遞參數(shù)并正常使用它們。
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 系統(tǒng)如果找不到你這個類,就會去自動調(diào)用本文件中的__autoload ($class_name) 方法,我們 new 的這個 class_name 就成為這個方法的參數(shù)。所以我們就可以在這個方法中根據(jù)我們需要 new class_name 的各種判斷和劃分就去 require 對應(yīng)的路徑類文件,從而實現(xiàn)自動加載。
spl_autoload_register 的使用:
如果一個項目過大,或者需要不同的自動加載來加載不同路徑的文件,這個時候 autoload 就不好用了,
原因是一個項目中只能有一個這樣的 autoload () 函數(shù),因為 PHP 不允許函數(shù)重名,
也就是說你不能聲明 2 個__autoload () 函數(shù)文件,否則會報致命錯誤,
所以,可以用新的 spl_autoload_register () 來取代它。并且,它執(zhí)行效率更高,更靈活。
以上是“php實現(xiàn)自動加載的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。