zoukankan      html  css  js  c++  java
  • spl_autoload_register(转载 http://blog.csdn.net/panpan639944806/article/details/23192267)

    在了解这个函数之前先来看另一个函数:__autoload。  

    一、__autoload  

    这是一个自动加载函数,在PHP5中,当我们实例化一个未定义的类时,就会触发此函数。看下面例子:  

    printit.class.php 
     
    <?php 
     
    class PRINTIT { 
     
     function doPrint() {
      echo 'hello world';
     }
    }
    ?> 
     
    index.php 
     
    <?
    function __autoload( $class ) {
     $file $class '.class.php';  
     if is_file($file) ) {  
      require_once($file);  
     }
     
    $obj new PRINTIT();
    $obj->doPrint();
    ?>

      

    运行index.php后正常输出hello world。在index.php中,由于没有包含printit.class.php,在实例化printit时,自动调用__autoload函数, 参数$class的值即为类名printit,此时printit.class.php就被引进来了。  

    在面向对象中这种方法经常使用,可以避免书写过多的引用文件,同时也使整个系统更加灵活。  

    二、spl_autoload_register()  

    再看spl_autoload_register(),这个函数与__autoload有与曲同工之妙,看个简单的例子:  

      
     
    <?
    function loadprint( $class ) {
     $file $class '.class.php';  
     if (is_file($file)) {  
      require_once($file);  
     
     
    spl_autoload_register( 'loadprint' ); 
     
    $obj new PRINTIT();
    $obj->doPrint();
    ?>

    将__autoload换成loadprint函数。但是loadprint不会像__autoload自动触发,这时spl_autoload_register()就起作用了,它告诉PHP碰到没有定义的类就执行loadprint()。 

    spl_autoload_register() 调用静态方法 

      
     
    <? 
     
    class test {
     public static function loadprint( $class ) {
      $file $class '.class.php';  
      if (is_file($file)) {  
       require_once($file);  
      
     }
     
    spl_autoload_register(  array('test','loadprint')  );
    //另一种写法:spl_autoload_register(  "test::loadprint"  ); 
     
    $obj new PRINTIT();
    $obj->doPrint();

    ?>

  • 相关阅读:
    Adaptive Cursor Sharing in Oracle Database 11g Release 1
    FORALL Support for NonConsecutive Indexes (Sparse Collections)
    设置会话TRACE的方法(一)
    Oracle 10g: UTL_MAIL
    Oracle :Parallel execution when table created.
    Server.MapPath
    Oracle10g :Nested Table Enhancements
    Asktom:Single Block IO Vs Multi Block IO
    Oracle10g新增DBMS_MONITOR包(一)
    设置会话TRACE的方法(二)
  • 原文地址:https://www.cnblogs.com/agang-php/p/5225193.html
Copyright © 2011-2022 走看看