1. 讓我們?yōu)?PHP 創(chuàng)建枚舉,提供一些代碼示例
如果我們的代碼需要對(duì)枚舉常量和值進(jìn)行更多驗(yàn)證,該怎么辦?
根據(jù)使用情況,我通常會(huì)使用類(lèi)似以下的簡(jiǎn)單內(nèi)容:
abstract class DaysOfWeek
{
const Sunday = 0;
const Monday = 1;
// etc.
}
$today = DaysOfWeek::Sunday;
這是一個(gè)擴(kuò)展的示例,可以更好地服務(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
2. 什么是 PHP 自動(dòng)加載類(lèi)?
使用自動(dòng)加載器,PHP 允許在由于錯(cuò)誤而失敗之前最后一次加載類(lèi)或接口。
PHP 中的 spl_autoload_register() 函數(shù)可以注冊(cè)任意數(shù)量的自動(dòng)加載器,即使未定義類(lèi)和接口也可以自動(dòng)加載。
spl_autoload_register(function ($classname) {
include $classname . '.php';
});
$object = new Class1();
$object2 = new Class2();
在上面的示例中,我們不需要包含 Class1.php 和 Class2.php。spl_autoload_register() 函數(shù)將自動(dòng)加載 Class1.php 和 Class2.php。
3. PHP 是否支持方法重載?
方法重載是使用具有不同簽名的相同方法名稱(chēng)的現(xiàn)象。PHP 中函數(shù)簽名僅基于它們的名稱(chēng),并且不包含參數(shù)列表,因此不能有兩個(gè)具有相同名稱(chēng)的函數(shù),所以 PHP 不支持方法重載。
但是,您可以聲明一個(gè)可變函數(shù),它接受可變數(shù)量的參數(shù)。您可以使用 func_num_args() 和 func_get_arg() 來(lái)傳遞參數(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);
問(wèn)答:不是有 __ autoload 嗎 為什么不用?
自動(dòng)加載的原理以及__autoload 的使用:
自動(dòng)加載的原理,就是在我們 new 一個(gè) class 的時(shí)候,PHP 系統(tǒng)如果找不到你這個(gè)類(lèi),就會(huì)去自動(dòng)調(diào)用本文件中的__autoload ($class_name) 方法,我們 new 的這個(gè) class_name 就成為這個(gè)方法的參數(shù)。所以我們就可以在這個(gè)方法中根據(jù)我們需要 new class_name 的各種判斷和劃分就去 require 對(duì)應(yīng)的路徑類(lèi)文件,從而實(shí)現(xiàn)自動(dòng)加載。
spl_autoload_register 的使用:
如果一個(gè)項(xiàng)目過(guò)大,或者需要不同的自動(dòng)加載來(lái)加載不同路徑的文件,這個(gè)時(shí)候 autoload 就不好用了,
原因是一個(gè)項(xiàng)目中只能有一個(gè)這樣的 autoload () 函數(shù),因?yàn)?PHP 不允許函數(shù)重名,
也就是說(shuō)你不能聲明 2 個(gè)__autoload () 函數(shù)文件,否則會(huì)報(bào)致命錯(cuò)誤,
所以,可以用新的 spl_autoload_register () 來(lái)取代它。并且,它執(zhí)行效率更高,更靈活。
到此這篇關(guān)于php自動(dòng)加載代碼實(shí)例詳解的文章就介紹到這了,更多相關(guān)php自動(dòng)加載內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- php框架CI(codeigniter)自動(dòng)加載與自主創(chuàng)建對(duì)象操作實(shí)例分析
- PHP類(lèi)的自動(dòng)加載與命名空間用法實(shí)例分析
- PHP 命名空間和自動(dòng)加載原理與用法實(shí)例分析
- PHP 自動(dòng)加載類(lèi)原理與用法實(shí)例分析
- PHP實(shí)現(xiàn)自動(dòng)加載機(jī)制