Maison >développement back-end >tutoriel php >méthode de chargement automatique php
Le contenu de cet article concerne la méthode de chargement automatique de php. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent se référer au contenu de cet article
. php chargement Méthode de fichier :
1. include, include_once, requice, requice_one chargement régulier
2. >3. spl_autoload_register()
Méthode de chargement générale
Supposons que nous ayons un fichier de classe A. php, Il définit une classe nommée A :<?php class A { public function __construct() { echo 'Got it.'; } }Mais il y a un problème, si notre index.php doit contenir non seulement la classe A, mais de nombreuses classes, cela doit écrire beaucoup de exiger des déclarations peut parfois mettre les gens mal à l'aise.
<?php require('A.php'); $a = new A();__autoload() se charge automatiquement Cependant, dans les versions après php5, nous n'avons plus besoin de faire cela.
En php5, la fonction __autoload est automatiquement appelée lorsque vous essayez d'utiliser une classe non définie, nous pouvons donc laisser php charger automatiquement la classe en écrivant la fonction __autoload sans avoir à écrire une longue liste de fichiers à inclure.
Par exemple, dans l'exemple ci-dessus, index.php peut être écrit comme ceci :
<?php function __autoload($class){ $file = $class . '.php'; if (is_file($file)) { require_once($file); } } $a = new A();
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不会出错。
以上就是本文的全部内容,希望对大家的学习有所帮助。
相关推荐:
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!