提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
前言
很多时候写面向对象的应用程序时会对每个类的定义建立一个php源文件。一个很大的烦恼就是不得不在每个脚本的开头写一个长长的包含文件列表(每个类的文件),对于每一个类的文件都需要使用require或者include手动引入。此时需要使用php提供的两个可用于自动加载文件的函数__autoload()和spl_autoload_register()函数。
1.__autoload()方法
当在代码中尝试加载未定义的类时会触发__autoload()函数。
void __autoload(string $class)
$class是待加载的类名,该函数没有返回值
使用例子:创建两个类文件,myclass类和yourclass类
<?php
class myclass{
function myname(){
echo "My Name is chenxiaoxiao";
}
}
?>
<?php
class youclass{
function yourname(){
echo "Your Name is chenxiaoxiao";
}
}
?>
在同目录下创建autoload.php文件
<?php
function __autoload($name){
if(file_exists($name.'.php')){
require_once $name.'.php';
}else{
echo "The path is error";
}
}
$my = new myclass();
$my->myname();
$your = new yourclass();
$your->yourname();
//输出结果:My Name is chenxiaoxiao Your Name is chenxiaoxiao
?>
运行到class时便会调用__autoload()函数,在__autoload()函数里实现了把相应类文件加载进来的功能。
2.spl_autoload_register()函数
可实现自动加载,以及注册给定的函数作为__autoload()的实现。
bool spl_autoload_register([callable $autoload_function [,bool $throw = true [,bool $prepend = false]]])
语法:$autoload_function是要注册的自动装载函数,如果没有提供参数,则自动注册autoload的默认实现函数spl_autoload_register(),throw 参数设置了autoload_function无法成功注册时spl_autoload_register()是否抛出异常,若throw为true或未设置,则抛出异常,为false则不抛出。
prepend如果是true,spl_autoload_register()会添加函数到队列之首,而不是队列尾部。
例子:创建两个类文件,myclass类和yourclass类
<?php
class myclass{
function myname(){
echo "My Name is chenxiaoxiao";
}
}
?>
<?php
class youclass{
function yourname(){
echo "Your Name is chenxiaoxiao";
}
}
?>
在同目录下创建autoload.php文件
<?php
function my_autoloader($class){
include $class.'.php';
}
spl_autoload_register('my_autoloader');
//或者使用一个匿名函数
spl_autoload_register(function($class){
include $class.'.php';
})
$my = new myclass();
$my->myname();
$your = new yourclass();
$your->yourname();
//输出结果:My Name is chenxiaoxiao Your Name is chenxiaoxiao
?>
以上两种方法都可实现自动加载文件。
本文介绍了PHP中用于自动加载文件的两种方法:__autoload()和spl_autoload_register()。__autoload()在尝试加载未定义的类时被触发,而spl_autoload_register()允许注册多个自动加载函数,并可控制加载顺序。通过这两个函数,开发者可以避免手动引入每个类文件,简化代码管理。

337

被折叠的 条评论
为什么被折叠?



