1.思考一个问题:
在一个php页面实例化时,必须先包含对应类文件,如果页面中实例化多个对象,怎么办呢?你可能会想,那就包含多个类文件嘛? 那如果这个对象是根据当前的参数动态实例化得到的,怎么办呢?
2.演示
假设我们有一个类文件B.php 在A中实例化这个类
A.php
require 'B.php';
$a = new B();
如果A中包含很多类,就会有很多require语句,让人感觉太累赘了,还好php5后提供了一个类文件自动加载机制就是
__autoload($className) 函数,使用该函数的时候要注意几点:
1.什么时候调用? --》当实例化一个不存在的类的时候,系统自动调用__autoload() 方法
2.接受什么参数? 接受当前实例化对象对应的类名,比如: new D() 传递参数就是:D
所以上面的代码可以变为:
A.php
function __autoload($className){
require $className.'.class.php';
}
__autoload 是系统定义的函数,那能不能我们自定义一个自动加载函数呢?当然是可以的,那就要用到php自的spl_autoload_register() 了,先看一个这个函数的定义:
bool spl_autoload_register ([ callback $autoload_function ] )
说明: callback可能值: 1.函数名 2.类中的一个静态方法 3.一个public权限的类方法
自定义自动加载函数:
spl_auto_register('my_autoload');
function my_autoload($className){
require $className.'.class.php';
}
注册类中的静态方法:
class Custom{
public static function my_autoload($className){
require $className.'.class.php';
}
}
spl_auto_register(array('Custom','my_autoload'));
$a =new A();
3.实际应用的会遇到的问题?
上面我们只是解决了自动加载某个目录下的类文件,在实际的开发过程类文件是放在多个不同的文件中的,那怎么解决呢?难道在每次自动加载函数中都指定好目录?
我们先研究一下require() 与include函数 这两个函数加载的时候都会根据 include_path设置的路径 来遍历加载目录,所以我们只要把类文件的目录添加到这里就行了
代码:
$directory = array('D:/web/','D:/webServer/classes/');
$include_path = implode(PHP_SEPARATOR,$directory);
//PHP_SEPATATOR 是路径分割符, PATH_SEPARATOR 在window下是';' ,在linux是':';
set_include_path(get_include_path().PATH_SEPARATOR.$include_path);
4.自动加载函数可以定义多个,执行的时候按照定义的顺序