php中autoload的实现机制

php5的autoload提供很好的加载文件的方法

当我们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过程 的解释

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值