php中SPL spl_autoload_register与__autoload方法使用
2013-09-05 18:33
525 查看
在php中spl_autoload_register与__autoload方法是php5才有的,下面我来给大家介绍这两个魔术函数的使用方法,大家可进入了解了解。
spl_autoload_register()函数应该是主流框架使用最多的也是非常核心的函数之一,可实现自动注册函数和类,实现类似__autoload() 函数功能,简化了类的调用与加载,提高了工作的效率。
支持版本:PHP 5 >= 5.1.2
至于效率问题。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指向这两个不同的函数地址来实现不同的自动加载机制。
代码如下
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 ;
}
}
// 注册一个 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] )
我们继续改写上面那个例子:
代码如下
view plaincopy to clipboardprint?
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了。同样的道理,下面这种写法也是可以的:
代码如下
view plaincopy to clipboardprint?
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();
spl_autoload_register()函数应该是主流框架使用最多的也是非常核心的函数之一,可实现自动注册函数和类,实现类似__autoload() 函数功能,简化了类的调用与加载,提高了工作的效率。
支持版本:PHP 5 >= 5.1.2
至于效率问题。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指向这两个不同的函数地址来实现不同的自动加载机制。
代码如下
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 ;
}
}
// 注册一个 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] )
我们继续改写上面那个例子:
代码如下
view plaincopy to clipboardprint?
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了。同样的道理,下面这种写法也是可以的:
代码如下
view plaincopy to clipboardprint?
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_autoload_register与__autoload方法使用
- 【PHP】__autoload()魔术方法与spl_autoload_register
- php spl_autoload_register函数使用
- php的autoload大致可以使用两种方法:__autoload和spl方法。这两种方法又各有不同的几种使用方法
- PHP中的__autoload()和spl_autoload_register()
- PHP自动加载 spl_autoload_register
- PHP spl_autoload_register实现自动加载研究
- 使用spl_autoload_register实现自动加载
- PHP自动加载类—__autoload()和spl_autoload_register() (补充)
- PHP中的__autoload()和spl_autoload_register()笔记
- 关于php中的spl_autoload_register
- PHP中autoload的使用方法
- PHP中spl_autoload_register()和__autoload()区别分析
- PHP的autload和spl_autoload_register
- PHP 使用__autoload()方法避免频繁使用require()函数。
- SPL spl_autoload_register与__autoload方法使用示例浅谈
- PHP中session_register函数详解使用方法
- PHP spl_autoload_register()函数的一些见解
- php命名空间+spl_autoload_register实现类的自动加载
- PHP - spl_autoload_register()函数