php中SPL spl_autoload_register与__autoload方法使用
在php中spl_autoload_register与__autoload方法是php5才有的,下面我来给大家介绍这两个魔术函数的使用方法,大家可进入了解了解.
spl_autoload_register()函数应该是主流框架使用最多的也是非常核心的函数之一,可实现自动注册函数和类,实现类似__autoload() 函数功能,简化了类的调用与加载,提高了工作的效率。
至于效率问题,php手册上有如此之话:bool spl_autoload_register ([ callback $autoload_function ] )
将函数注册到SPL __autoload函数栈中。如果该栈中的函数尚未激活,则激活它们。如果在你的程序中已经实现了__autoload函数,它必须显式注册到__autoload栈中。因为spl_autoload_register()函数会将Zend Engine中的__autoload函数取代为spl_autoload()或spl_autoload_call()。
spl_autoload_register
(PHP 5 >= 5.1.2)
spl_autoload_register — 注册__autoload()函数
说明: bool spl_autoload_register ([ callback $autoload_function ] )
将函数注册到SPL __autoload函数栈中,如果该栈中的函数尚未激活,则激活它们,如果在你的程序中已经实现了__autoload函数,它必须显式注册到__autoload栈中,因为spl_autoload_register()函数会将Zend Engine中的__autoload函数取代为spl_autoload()或spl_autoload_call().
参数: autoload_function 欲注册的自动装载函数,如果没有提供任何参数,则自动注册autoload的默认实现函数
spl_autoload()。
返回值 :如果成功则返回 TRUE,失败则返回 FALSE.
注: SPL是Standard PHP Library(标准PHP库)的缩写,它是PHP5引入的一个扩展库,其主要功能包括autoload机制的实现及包括各种Iterator接口或类,SPL autoload机制的实现是通过将函数指针autoload_func指向自己实现的具有自动装载功能的函数来实现的,SPL有两个不同的函数 spl_autoload,spl_autoload_call,通过将autoload_func指向这两个不同的函数地址来实现不同的自动加载机制,代码如下:
<?php class autoload { public static function load( $class name ) { $filename = $classname . ".class.php" ; if ( file_exists ( $filename )) { require_once $filename ; } } } function __autoload( $class name ) { // 这个是默认的 autoload 方法 $filename = $classname . ".class.php" ; if ( file_exists ( $filename )) { require_once $filename ; } //开源代码phpfensi测试数据 } // 注册一个 autoloader spl_autoload_register( 'autoload::load' ); spl_autoload_register( '__autoload' ); // 注:下面的类看上去没有定义,但其实系统根据sql_autoload_register提供的路径会自动去搜索 //foo.class.php文件,如果没找到才报错。 $foo = new foo(); $foo ->bar(); ?>在补充下: __autoload 方法在 spl_autoload_register 后会失效,因为 autoload_func 函数指针已指向 spl_autoload 方法.
可以通过下面的方法来把 _autoload 方法加入 autoload_functions list
spl_autoload_register( '__autoload' );
此外我们还可以使用我们自定义的加载方法.
第一种函数式,代码如下:
function my_own_loader( $classname ) { $class_file = strtolower ( $classname ). ".php" ; if ( file_exists ( $class_file )){ require_once ( $class_file ); } } spl_autoload_register( "my_own_loader" ); $a = new A();第二种类式,代码如下:
class Loader { public static function my_own_loader( $classname ) { $class_file = strtolower ( $classname ). ".php" ; if ( file_exists ( $class_file )){ require_once ( $class_file ); } } } // 通过数组的形式传递类和方法的名称 spl_autoload_register( array ( "Loader" , "my_own_loader" )); $a = new A();实例:CI框架实现类加载的同时,其对应的model也生成,代码如下:
static public function myAutoload( $class ){ if ( file_exists (APPPATH. 'models' .DIRECATORY_SEPARATOR. $class . '.php' )){ require_once APPPATH. 'models' .DIRECATORY_SEPARATOR. $class . '.php' ; } } /** * 注册加载器 */ static public function autoload(){ spl_autoload_register( array ( __CLASS__ , 'myAutoload' )); if ( class_exists ( '__autoload' )){ spl_autoload_register( '__autoload' ); } } MY_Controller::autoload();当然上面只是最简单的示范,__autoload只是去include_path寻找类文件并加载,我们可以根据自己的需要定义__autoload加载类的规则.
此外,假如我们不想自动加载的时候调用__autoload,而是调用我们自己的函数(或者类方法),我们可以使用spl_autoload_register来注册我们自己的autoload函数,它的函数原型如下:
bool spl_autoload_register ( [callback $autoload_function] )
我们继续改写上面那个例子,代码如下:
function loader( $class ) { $file = $class . '.php' ; if ( is_file ( $file )) { require_once ( $file ); } } spl_autoload_register( 'loader' ); $a = new A(); function loader( $class ) { $file = $class . '.php' ; if ( is_file ( $file )) { require_once ( $file ); } } spl_autoload_register( 'loader' ); $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' )); $a = new A(); ?>查看更多关于php中SPL spl_autoload_register与__autoload方法使用 - ph的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did31048