序言
在第三篇文章中,我们看到了文件的自动加载,这块我提出来在仔细的说一下这块。
如你看到这篇文章对PHP秒杀系统感兴趣,那么可以点击图像查看连载的文章。
源码在第二篇文章可以看到,自行拉取
1. 类文件的自动加载器
1. 我们的项目目录下,所有的服务端代码都引入了一个共同的文件那就是init.PHP
2. 在这个文件中,我们加载了俩个配置文件,我们先看global.inc.PHP
3. spl_autoload_register() 作为 __autoload() 函数的替代,返回true
4 . 过程详解
我们可以打印一下$class_name
由于我们项目是在linux上存放,linux上是不能反斜杠的,所以需要在把斜杠转为正斜杠
然后拼接路径并判断文件是否存在
然后在类外调用一下即可
2. 解释文件类加载器
如果一个类在多个脚本中都需要使用,可以将一个类的定义代码,单独的封装到一个文件中,这种文件也叫作类文件,在需要的时候,将整个文件载入进来即可!
PHP在执行的时候,如果发现需要一个类(只要是和这个类相关的任何的操作),但此时当前脚本又没有这个类的定义代码,也没有手动加载这个类文件,那么,PHP会自动的调用一个名字叫作__autoload($class_name)函数,调用的时候,会给该函数传递一个参数,该参数就是当前所需要的类的类名!
3. 检验
然后打印就可以看到class_name
但我们没有这个文件,所以会报出file not exists
3. 源码
//自定义类自动加载路径
define('CUSTOM_CLASS_PATH',ROOT_PATH . '/class');
define ('DIRECTORY_SEParaTOR',"/");
/**
* Class SYscore
* 类文件的自动加载器
*/
class SYscore {
public static function registerautoload($class = 'SYscore') {
spl_autoload_register(array($class,'autoload'));
}
public static function unregisterautoload($class) {
spl_autoload_unregister(array($class,'autoload'));
}
public static function my_callback($match){
return DIRECTORY_SEParaTOR. $match[0];
}
public static function autoload($class_name) {
if (strpos($class_name,'common') === 0
|| strpos($class_name,'model') === 0
|| strpos($class_name,'MysqL') === 0
|| strpos($class_name,'Curl') === 0
|| strpos($class_name,'controller') === 0
) {
// 系统内部自定义的类域名空间
} else {
return true;
}
$class_name = str_replace('\\','/',$class_name);
$class_path = CUSTOM_CLASS_PATH . DIRECTORY_SEParaTOR . $class_name.'.PHP';
$class_path = str_replace('//',$class_path);
# 判断文件是否存在
if(file_exists($class_path)) {
# 如果存在则引入
return include_once($class_path);
} else {
# 报出警告信息
echo "file not exists class_path=$class_path\n<br/>";
}
return false;
}
}
SYscore::registerautoload();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。