Heim > Artikel > Backend-Entwicklung > PHP-Methode zum automatischen Laden
Der Inhalt dieses Artikels handelt von der automatischen Lademethode von PHP. Jetzt können Freunde in Not auf den Inhalt dieses Artikels verweisen
PHP-Lademethode:
1. include, include_once, requice, requice_one regelmäßiges Laden
2. __autoload()
3. spl_autoload_register()
Allgemeine Lademethode
Angenommen, wir haben eine Klassendatei A. php, Es definiert eine Klasse mit dem Namen A:
<?php class A { public function __construct() { echo 'Got it.'; } }
Dann haben wir eine index.php, die diese Klasse A verwenden muss. Die herkömmliche Schreibmethode ist
<?php require('A.php'); $a = new A();
Aber es gibt ein Problem: Wenn unsere index.php nicht nur Klasse A, sondern viele Klassen enthalten muss, muss dies viel geschrieben werden Erforderliche Aussagen können bei Menschen manchmal ein Unbehagen hervorrufen.
__autoload() lädt automatisch
In Versionen nach PHP5 müssen wir dies jedoch nicht mehr tun.
In PHP5 wird die __autoload-Funktion automatisch aufgerufen, wenn versucht wird, eine undefinierte Klasse zu verwenden, sodass wir PHP die Klasse automatisch laden lassen können, indem wir die __autoload-Funktion schreiben, ohne eine lange Liste von Include-Dateien schreiben zu müssen.
Zum Beispiel kann index.php im obigen Beispiel so geschrieben werden:
<?php function __autoload($class){ $file = $class . '.php'; if (is_file($file)) { require_once($file); } } $a = new A();
Natürlich ist das Obige nur so Die einfachste Demonstration, __autoload Gehen Sie einfach zu include_path, um die Klassendatei zu finden und zu laden. Wir können die __autoload-Regeln zum Laden von Klassen entsprechend unseren eigenen Anforderungen definieren. Hinweis: Da __autoload() eine Funktion ist, kann sie nur einmal existieren.
spl_autoload_register()自动加载
但现在问题来了,如果在一个系统的实现中,如果需要使用很多其它的类库,这些类库可能是由不同的开发人员编写的,其类名与实际的磁盘文件的映射规则不尽相同。这时如果要实现类库文件的自动加载,就必须在__autoload()函数中将所有的映射规则全部实现,这样的话__autoload()函数有可能 会非常复杂,甚至无法实现。最后可能会导致__autoload()函数十分臃肿,这时即便能够实现,也会给将来的维护和系统效率带来很大的负面影响。在这种情况下,难道就没有更简单清晰的解决办法了吧?答案当然是:NO!
spl_autoload_register() 满足了此类需求。 它实际上创建了 autoload 函数的队列,按定义时的顺序逐个执行。相比之下, __autoload() 只可以定义一次。
bool spl_autoload_register ([ callable $autoload_function [, bool $throw = true [, bool $prepend = false ]]] )
我们继续改写上面那个例子:
<?php function loader($class){ $file = $class . '.php'; if (is_file($file)) { require_once($file); } } spl_autoload_register('loader'); $a = new A();
或者直接使用匿名函数:
<?php spl_autoload_register(function($file){ $file = $class . '.php'; if (is_file($file)) { require_once($file); } }); $a = new A();
这样子也是可以正常运行的,这时候php在寻找类的时候就没有调用__autoload而是调用我们自己定义的函数loader了。同样的道理,下面这种写法也是可以的:
<?php class Loader { public static function loadClass($class){ $file = $class . '.php'; if (is_file($file)) { require_once($file); } } } spl_autoload_register(array('Loader', 'loadClass')); //spl_autoload_register(array(__CLASS__, 'loadClass')); //spl_autoload_register(array($this, 'loadClass')); $a = new A();
更多示例
autoload.php
<?php define('SDK_PATH', __DIR__); require_once SDK_PATH . '/common/functions.php'; require_once SDK_PATH . '/common/config.php'; spl_autoload_register(function ($class) { if (false !== stripos($class, 'YJC\Wechat')) { require_once __DIR__ . '/' . str_replace('\\', DIRECTORY_SEPARATOR, substr($class, 10)) . '.php'; } }); /* function __autoload($class){ if (false !== stripos($class, 'YJC\Wechat')) { require_once __DIR__ . '/' . str_replace('\\', DIRECTORY_SEPARATOR, substr($class, 10)) . '.php'; } } */
建议入口文件里养成定义绝对地址SDK_PATH的习惯,这样require不会出错。
以上就是本文的全部内容,希望对大家的学习有所帮助。
相关推荐:
Das obige ist der detaillierte Inhalt vonPHP-Methode zum automatischen Laden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!