知识屋:更实用的电脑技术知识网站
所在位置:首页 > 编程技术 > PHP编程

php的自动加载机制

发布时间:2014-09-05 10:33:24作者:知识屋

一、php中实现自动加载的方法

 

使用require,include,require_once,include_once手工进行加载。

使用__autoload来进行自动加载
使用spl的autoload来实现自动加载
手工加载的实现:

当需要加载的文件很少的时候我们可以使用第一个来完成。这样做很简单也没问题。


[php]
require_once 'a.php'; 
require_once 'b.php'; 
require_once 'c.php'; 

require_once 'a.php';
require_once 'b.php';
require_once 'c.php';
但是当需要加载文件很多的时候这样做还行吗?需要写十个,二十个require_once 或者更多的时候我们该怎么办?

这个时候我们可以使用__autoload方法来简化我们的代码。

__autoload加载的实现:

我们在test目录下创建一个in.php文件,内容如下。


[php]
echo '我是test下面的in.php<br />'; 

echo '我是test下面的in.php<br />';然后在test目录下创建一个loader.php,内容如下。

[php]
// 需要重载__autoload方法,自定义包含类文件的路径    
function __autoload($classname)   
{   
    $class_file = strtolower($classname).".php";   
    if (file_exists($class_file)){   
        require_once($class_file);   
    }   

@$test = new in(); // 执行到这里会输出 <SPAN style="FONT-FAMILY: Arial, Helvetica, sans-serif">我是test下面的in.php</SPAN> 

// 需要重载__autoload方法,自定义包含类文件的路径 
function __autoload($classname) 

 $class_file = strtolower($classname).".php"; 
 if (file_exists($class_file)){ 
  require_once($class_file); 
 } 
}
@$test = new in(); // 执行到这里会输出 我是test下面的in.php没问题,成功了!我们还可以创建其他的文件来进行加载,但是当需要的文件很多需要区分目录的时候怎么办?

这时我们需要修改loader.php可以使用映射来找到要加载的文件。


[php]
function __autoload($class_name) { 
    $map = array( 
        'index' => './include/index.php', 
        'in'    => './in.php' 
    ); 
 
    if (file_exists($map[$class_name]) && isset($map[$class_name])) { 
        require_once $map[$class_name]; 
    } 

new index();  

function __autoload($class_name) {
 $map = array(
  'index' => './include/index.php',
  'in' => './in.php'
 );

    if (file_exists($map[$class_name]) && isset($map[$class_name])) {
        require_once $map[$class_name];
    }
}
new index();

这种方法的好处就是类名和文件路径只是用一个映射来维护,所以当文件结构改变的时候,不需要修改类名,只需要将映射中对应的项修改就好了。

但是__autoload在一个项目中只能使用一次,当你的项目引用了别人的一个项目,你的项目中有一个__autoload,别人的项目也有一个__autoload,这样两个__autoload就冲突了.解决的办法就是修改__autoload成为一个,这无疑是非常繁琐的,应用场景单一。


spl的autoload加载实现:

spl的autoload系列函数使用一个autoload调用堆栈,你可以使用spl_autoload_register注册多个自定义的autoload函数,应用场景广泛


spl的自动加载的相关函数/spl_autoload%20是_autoload()的默认实现,它会去include_path中寻找$class_name(.php/.inc)%20Spl_autoload实现自动加载:在test目录下建立in.php,内容如下  

[php]<?php class%20in%20{    %20public%20function%20index()%20{        %20echo%20'我是test下面的in.php';    %20} ?> 

<?phpclass%20in%20{ public%20function%20index()%20{  echo%20'我是test下面的in.php'; }}?>       %20在test目录下建立loader.php,内容如下[html]<?php set_include_path("/var/www/test/");%20//这里需要将路径放入include spl_autoload("in");%20//寻找/var/www/test/in.php $in%20=%20new%20in(); $in->index(); 

<?phpset_include_path("/var/www/test/");%20//这里需要将路径放入includespl_autoload("in");%20//寻找/var/www/test/in.php$in%20=%20new%20in();$in->index();spl_autoload_register将函数注册到SPL%20__autoload函数栈中,修改loader.php[php]function%20AutoLoad($class){    %20if($class%20==%20'in'){        %20require_once("/var/www/test/in.php");    %20} spl_autoload_register('AutoLoad'); $a%20=%20new%20in(); $a->index(); 

function%20AutoLoad($class){   %20if($class%20==%20'in'){       %20require_once("/var/www/test/in.php");   %20}}spl_autoload_register('AutoLoad');$a%20=%20new%20in();$a->index();

 

spl_autoload_register注册多个自定义的autoload函数的应用首先在test目录下建立mods文件夹并建立inmod.mod.php内容如下:[php]<?php class%20inmod    %20function%20__construct()    %20{        %20echo%20'我是mods下的in';    %20} 

<?phpclass%20inmod{ function%20__construct() {  echo%20'我是mods下的in'; }}         %20然后在test目录下建立libs文件夹并建立inlib.lib.php内容如下:[php]<?php class%20inlib    %20function%20__construct()    %20{        %20echo%20'我是libs下的in';    %20} 

<?phpclass%20inlib{ function%20__construct() {  echo%20'我是libs下的in'; }}          %20最后在test目录下建立loader.php内容如下[php]<?php class%20Loader%20{    %20/**   %20*%20自动加载类   %20*%20@param%20$class%20类名   %20*/    %20public%20static%20function%20mods($class)%20{        %20if($class){            %20set_include_path(%20"/var/www/test/mods/"%20);            %20spl_autoload_extensions(%20".mod.php"%20);            %20spl_autoload(%20strtolower($class)%20);        %20}    %20}    %20public%20static%20function%20libs($class)%20{        %20if($class){            %20set_include_path(%20"/var/www/test/libs/"%20);            %20spl_autoload_extensions(%20".lib.php"%20);            %20spl_autoload(%20strtolower($class)%20);        %20}    %20} spl_autoload_register(array('Loader',%20'mods')); spl_autoload_register(array('Loader',%20'libs')); new%20inmod();//输出<SPAN%20style="FONT-FAMILY:%20'Times%20New%20Roman';%20FONT-SIZE:%2014px">我是mods下的in</SPAN>  new%20inlib();//<SPAN%20style="FONT-FAMILY:%20Arial,%20Helvetica,%20sans-serif">输出</SPAN><SPAN%20style="FONT-FAMILY:%20'Times%20New%20Roman';%20FONT-SIZE:%2014px">我是libs下的in</SPAN> 

<?phpclass%20Loader%20{   %20/**   %20*%20自动加载类   %20*%20@param%20$class%20类名   %20*/   %20public%20static%20function%20mods($class)%20{       %20if($class){   set_include_path(%20"/var/www/test/mods/"%20);   spl_autoload_extensions(%20".mod.php"%20);   spl_autoload(%20strtolower($class)%20);       %20}   %20}   %20public%20static%20function%20libs($class)%20{  if($class){   set_include_path(%20"/var/www/test/libs/"%20);   spl_autoload_extensions(%20".lib.php"%20);   spl_autoload(%20strtolower($class)%20);       %20}   %20}}spl_autoload_register(array('Loader',%20'mods'));spl_autoload_register(array('Loader',%20'libs'));new%20inmod();//输出我是mods下的innew%20inlib();//输出我是libs下的in

 

(免责声明:文章内容如涉及作品内容、版权和其它问题,请及时与我们联系,我们将在第一时间删除内容,文章内容仅供参考)
收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜