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!

推薦閱讀: