php中autoload的实现机制
2014-04-24 09:20
543 查看
php5的autoload提供很好的加载文件的方法
当我们new一个对象的时候 对象写在一个文件里,这时候需要加载(include)文件进来才能new成功
当文件很多的时候 需要写很多的include 不方便,php5提供的自动加载方案解决了这样的问题
当我们new一个class的时候 系统会在include_path 中查找名字为class的文件
php不会在查找class的时候(通过include_path)是不会加载你自己的class文件的,即使你添加了include_path
$path=dirname(__FILE__).'\classes\\';
set_include_path(get_include_path().PATH_SEPARATOR.$path);
$o = new foo();
echo $o->index();
加载的实现还是在autoload函数里面
spl_autoload($class_name,$ext) 函数是 __autoload() 的默认实现 调用__autoload() 就不会调用这个函数
spl_autoload 在include_path里面寻找$class_name 第二个参数可指定文件扩展名 默认为 .inc .php
总之,以上的实现方式都是用 __autoload() 函数 , 这个函数就一个 也就是我们自己定义的加载方式就只有 __autoload() 中的这一种
改善这种困境的方案是 spl_autoload_register(callback func) 方法 __autoload 以后将被弃用 使用 spl_autoload_register 代替
我们可以注册多种回调函数作为加载的实现
这是官网对 spl_autoload_register 函数的解释 有利于我们识别出 整个autoload的过程 以及 __autoload 函数与 spl_autoload_register 函数的区别
这里有一个对SPL过程 的解释
当我们new一个对象的时候 对象写在一个文件里,这时候需要加载(include)文件进来才能new成功
include 'myClass.php'; $m = new myClass();
当文件很多的时候 需要写很多的include 不方便,php5提供的自动加载方案解决了这样的问题
当我们new一个class的时候 系统会在include_path 中查找名字为class的文件
php不会在查找class的时候(通过include_path)是不会加载你自己的class文件的,即使你添加了include_path
$path=dirname(__FILE__).'\classes\\';
set_include_path(get_include_path().PATH_SEPARATOR.$path);
$o = new foo();
echo $o->index();
加载的实现还是在autoload函数里面
function __autoload($class_name) { $path=dirname(__FILE__).'\classes\\'; require_once($path.$class_name.'.php'); } $o = new foo(); echo $o->index();
spl_autoload($class_name,$ext) 函数是 __autoload() 的默认实现 调用__autoload() 就不会调用这个函数
spl_autoload 在include_path里面寻找$class_name 第二个参数可指定文件扩展名 默认为 .inc .php
$path=dirname(__FILE__).'\classes\\'; set_include_path(get_include_path().PATH_SEPARATOR.$path); //添加目录到include_path // var_dump(get_include_path()); spl_autoload('foo'); $o = new foo(); echo $o->index();
总之,以上的实现方式都是用 __autoload() 函数 , 这个函数就一个 也就是我们自己定义的加载方式就只有 __autoload() 中的这一种
改善这种困境的方案是 spl_autoload_register(callback func) 方法 __autoload 以后将被弃用 使用 spl_autoload_register 代替
我们可以注册多种回调函数作为加载的实现
spl_autoload_register('func1'); spl_autoload_register('func2'); spl_autoload_register('func3'); function func1(){} function func2(){} function func3(){} var_dump(spl_autoload_functions());
这是官网对 spl_autoload_register 函数的解释 有利于我们识别出 整个autoload的过程 以及 __autoload 函数与 spl_autoload_register 函数的区别
将函数注册到SPL __autoload函数栈中。如果该栈中的函数尚未激活,则激活它们。 如果在你的程序中已经实现了__autoload函数,它必须显式注册到__autoload栈中。因为 spl_autoload_register()函数会将Zend Engine中的__autoload函数取代为spl_autoload()或spl_autoload_call()。
这里有一个对SPL过程 的解释
相关文章推荐
- PHP的autoload机制的实现解析
- PHP的autoload机制的实现
- php的autoload机制的实现解析
- PHP的autoload机制的实现解析
- PHP文件的执行和PHP 的 autoload 机制的实现
- PHP如何实现“autoload”机制详解
- PHP的autoload机制的实现解析
- PHP的autoload机制的实现解析
- PHP的autoload机制的实现解析
- PHP 反射机制详解 以及插件架构实现
- PHP autoload机制详解
- 利用php的ob缓存机制实现页面静态化方法
- PHP 反射机制实现动态代理的代码
- PHP behavior 机制简单实现
- PHP反射API实现插件机制
- PHP反射机制实现自动依赖注入
- PHP实现依赖注入-使用反射机制和动态代理技术 - 简单思想(咋个办呢 zgbn)
- PHP的autoload自动加载机制实例
- PHP 反射机制实现动态代理的代码
- PHP实现事件机制的方法